CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
List of all members | Public Member Functions | Private Member Functions | Private Attributes
FWConversionProxyBuilder Class Reference
Inheritance diagram for FWConversionProxyBuilder:
FWSimpleProxyBuilderTemplate< reco::Conversion > FWSimpleProxyBuilder FWProxyBuilderBase

Public Member Functions

virtual void cleanLocal ()
 
 FWConversionProxyBuilder ()
 
virtual bool haveSingleProduct () const
 
 REGISTER_PROXYBUILDER_METHODS ()
 
virtual ~FWConversionProxyBuilder ()
 
- Public Member Functions inherited from FWSimpleProxyBuilderTemplate< reco::Conversion >
 FWSimpleProxyBuilderTemplate ()
 
- Public Member Functions inherited from FWSimpleProxyBuilder
 FWSimpleProxyBuilder (const std::type_info &iType)
 
virtual ~FWSimpleProxyBuilder ()
 
- Public Member Functions inherited from FWProxyBuilderBase
void build ()
 
virtual bool canHandle (const FWEventItem &)
 
const fireworks::Contextcontext () const
 
TEveElementList * createProduct (FWViewType::EType, const FWViewContext *)
 
 FWProxyBuilderBase ()
 
bool getHaveWindow () const
 
virtual bool havePerViewProduct (FWViewType::EType) const
 
const FWEventItemitem () const
 
virtual void itemBeingDestroyed (const FWEventItem *)
 
void itemChanged (const FWEventItem *)
 
int layer () const
 
void modelChanges (const FWModelIds &)
 
void removePerViewProduct (FWViewType::EType, const FWViewContext *vc)
 
void scaleChanged (const FWViewContext *)
 
void setHaveWindow (bool iFlag)
 
virtual void setInteractionList (FWInteractionList *, const std::string &)
 
virtual void setItem (const FWEventItem *iItem)
 
void setupAddElement (TEveElement *el, TEveElement *parent, bool set_color=true) const
 
void setupElement (TEveElement *el, bool color=true) const
 
virtual bool willHandleInteraction () const
 
virtual ~FWProxyBuilderBase ()
 

Private Member Functions

virtual void buildViewType (const reco::Conversion &iData, unsigned int iIndex, TEveElement &oItemHolder, FWViewType::EType type, const FWViewContext *)
 
 FWConversionProxyBuilder (const FWConversionProxyBuilder &)
 
const FWConversionProxyBuilderoperator= (const FWConversionProxyBuilder &)
 
TEveElementList * requestCommon ()
 

Private Attributes

TEveElementList * m_common
 

Additional Inherited Members

- Static Public Member Functions inherited from FWSimpleProxyBuilder
static std::string typeOfBuilder ()
 Used by the plugin system to determine how the proxy uses the data from FWEventItem. More...
 
- Static Public Member Functions inherited from FWProxyBuilderBase
static bool representsSubPart ()
 
static std::string typeOfBuilder ()
 Used by the plugin system to determine how the proxy uses the data from FWEventItem. More...
 
- Protected Types inherited from FWProxyBuilderBase
typedef std::vector< Product * >
::iterator 
Product_it
 
- Protected Member Functions inherited from FWSimpleProxyBuilderTemplate< reco::Conversion >
const reco::ConversionmodelData (int index)
 
- Protected Member Functions inherited from FWSimpleProxyBuilder
virtual void build (const FWEventItem *iItem, TEveElementList *product, const FWViewContext *)
 
virtual void buildViewType (const FWEventItem *iItem, TEveElementList *product, FWViewType::EType viewType, const FWViewContext *)
 
virtual void clean ()
 
- Protected Member Functions inherited from FWProxyBuilderBase
TEveCompound * createCompound (bool set_color=true, bool propagate_color_to_all_children=false) const
 
 FWProxyBuilderBase (const FWProxyBuilderBase &)
 
void increaseComponentTransparency (unsigned int index, TEveElement *holder, const std::string &name, Char_t transpOffset)
 
virtual void localModelChanges (const FWModelId &iId, TEveElement *iCompound, FWViewType::EType viewType, const FWViewContext *vc)
 
virtual void modelChanges (const FWModelIds &, Product *)
 
const FWProxyBuilderBaseoperator= (const FWProxyBuilderBase &)
 
virtual void scaleProduct (TEveElementList *parent, FWViewType::EType, const FWViewContext *vc)
 
- Protected Attributes inherited from FWSimpleProxyBuilder
FWSimpleProxyHelper m_helper
 
- Protected Attributes inherited from FWProxyBuilderBase
std::vector< Product * > m_products
 

Detailed Description

Definition at line 35 of file FWConversionProxyBuilder.cc.

Constructor & Destructor Documentation

FWConversionProxyBuilder::FWConversionProxyBuilder ( )

Definition at line 58 of file FWConversionProxyBuilder.cc.

References m_common.

58  :
59  m_common(0)
60 {
61  m_common = new TEveElementList( "common conversion scene" );
62  m_common->IncDenyDestroy();
63 }
FWConversionProxyBuilder::~FWConversionProxyBuilder ( )
virtual

Definition at line 65 of file FWConversionProxyBuilder.cc.

References m_common.

66 {
67  m_common->DecDenyDestroy();
68 }
FWConversionProxyBuilder::FWConversionProxyBuilder ( const FWConversionProxyBuilder )
private

Member Function Documentation

void FWConversionProxyBuilder::buildViewType ( const reco::Conversion iData,
unsigned int  iIndex,
TEveElement &  oItemHolder,
FWViewType::EType  type,
const FWViewContext  
)
privatevirtual

Reimplemented from FWSimpleProxyBuilderTemplate< reco::Conversion >.

Definition at line 118 of file FWConversionProxyBuilder.cc.

References geometryCSVtoXML::line, groupFilesInBlocks::lines, requestCommon(), and FWProxyBuilderBase::setupAddElement().

119 {
120  TEveElementList* lines = requestCommon();
121  TEveElement::List_i linIt = lines->BeginChildren();
122  std::advance(linIt, iIndex);
123  TEveLine* line = (TEveLine*)((*linIt)->CloneElement());
124  TEveVector bvec = line->GetLineStart();
125  TEveVector evec = line->GetLineEnd();
126  if (bvec.Mag() != evec.Mag())
127  setupAddElement(*linIt, &oItemHolder );
128 }
void setupAddElement(TEveElement *el, TEveElement *parent, bool set_color=true) const
void FWConversionProxyBuilder::cleanLocal ( )
virtual

Reimplemented from FWProxyBuilderBase.

Definition at line 112 of file FWConversionProxyBuilder.cc.

References m_common.

113 {
114  m_common->DestroyElements();
115 }
virtual bool FWConversionProxyBuilder::haveSingleProduct ( void  ) const
inlinevirtual

Reimplemented from FWProxyBuilderBase.

Definition at line 41 of file FWConversionProxyBuilder.cc.

41 { return false; }
const FWConversionProxyBuilder& FWConversionProxyBuilder::operator= ( const FWConversionProxyBuilder )
private
FWConversionProxyBuilder::REGISTER_PROXYBUILDER_METHODS ( )
TEveElementList * FWConversionProxyBuilder::requestCommon ( )
private

Definition at line 71 of file FWConversionProxyBuilder.cc.

References fireworks::Context::caloR1(), fireworks::Context::caloTransEta(), fireworks::Context::caloZ1(), edm::conversion(), funct::cos(), funct::false, i, FWProxyBuilderBase::item(), geometryCSVtoXML::line, m_common, FWSimpleProxyBuilderTemplate< reco::Conversion >::modelData(), reco::Conversion::nTracks(), reco::Conversion::pairMomentum(), phi, CosmicsPD_Skims::radius, FWProxyBuilderBase::setupElement(), funct::sin(), FWEventItem::size(), funct::tan(), detailsBasic3DVector::z, and reco::Conversion::zOfPrimaryVertexFromTracks().

Referenced by buildViewType().

72 {
73  if( m_common->HasChildren() == false )
74  {
75  for (int i = 0; i < static_cast<int>(item()->size()); ++i)
76  {
78  TEveLine* line = new TEveLine(0);
79  if (conversion.nTracks() == 2) {
80  if (fabs(conversion.zOfPrimaryVertexFromTracks()) < fireworks::Context::caloZ1())
81  line->SetNextPoint(0., 0., conversion.zOfPrimaryVertexFromTracks());
82  else
83  line->SetNextPoint(0., 0., 0.);
84 
85  float phi = conversion.pairMomentum().phi();
86  if (fabs(conversion.pairMomentum().eta()) < fireworks::Context::caloTransEta()) {
88  float z = radius/tan(conversion.pairMomentum().theta());
89  line->SetNextPoint(radius*cos(phi), radius*sin(phi), z);
90  }
91  else {
92  float z = fireworks::Context::caloZ1();
93  float radius = z*tan(conversion.pairMomentum().theta());
94  z *= (conversion.pairMomentum().eta()/fabs(conversion.pairMomentum().eta()));
95  line->SetNextPoint(radius*cos(phi), radius*sin(phi), z);
96  }
97  }
98  else {
99  line->SetNextPoint(0., 0., 0.);
100  line->SetNextPoint(0., 0., 0.);
101  }
102 
103  setupElement( line );
104  m_common->AddElement( line );
105  }
106  }
107 
108  return m_common;
109 }
static float caloTransEta()
Definition: Context.cc:230
int i
Definition: DBlmapReader.cc:9
Sin< T >::type sin(const T &t)
Definition: Sin.h:22
double zOfPrimaryVertexFromTracks(const math::XYZPoint &myBeamSpot=math::XYZPoint()) const
Definition: Conversion.h:149
float float float z
const FWEventItem * item() const
Cos< T >::type cos(const T &t)
Definition: Cos.h:22
static float caloR1(bool offset=true)
Definition: Context.cc:210
Tan< T >::type tan(const T &t)
Definition: Tan.h:22
unsigned int nTracks() const
Number of tracks= 0,1,2.
Definition: Conversion.h:105
math::XYZVectorF pairMomentum() const
Conversion tracks momentum from the tracks inner momentum.
Definition: Conversion.cc:227
void conversion(EventAux const &from, EventAuxiliary &to)
Definition: EventAux.cc:9
size_t size() const
Definition: FWEventItem.cc:549
static float caloZ1(bool offset=true)
Definition: Context.cc:220
void setupElement(TEveElement *el, bool color=true) const
Definition: DDAxes.h:10

Member Data Documentation

TEveElementList* FWConversionProxyBuilder::m_common
private