CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
FWSiPixelDigiProxyBuilder.cc
Go to the documentation of this file.
1 // -*- C++ -*-
2 //
3 // Package: Tracks
4 // Class : FWSiPixelDigiProxyBuilder
5 //
6 //
7 // Original Author:
8 // Created: Thu Dec 6 18:01:21 PST 2007
9 //
10 
11 #include "TEveCompound.h"
12 #include "TEvePointSet.h"
13 
19 
22 
24 {
25 public:
27  virtual ~FWSiPixelDigiProxyBuilder( void ) {}
28 
30 
31 private:
32  // Disable default copy constructor
34  // Disable default assignment operator
36 
37  virtual void build( const FWEventItem* iItem, TEveElementList* product, const FWViewContext* ) override;
38 };
39 
40 void FWSiPixelDigiProxyBuilder::build( const FWEventItem* iItem, TEveElementList* product, const FWViewContext* )
41 {
42  const edm::DetSetVector<PixelDigi>* digis = 0;
43  iItem->get( digis );
44 
45  if( ! digis )
46  {
47  return;
48  }
49  const FWGeometry *geom = iItem->getGeom();
50 
51  for( edm::DetSetVector<PixelDigi>::const_iterator it = digis->begin(), end = digis->end();
52  it != end; ++it )
53  {
54  edm::DetSet<PixelDigi> ds = *it;
55  unsigned int id = ds.id;
56 
57  const float* pars = geom->getParameters( id );
58 
59  for( edm::DetSet<PixelDigi>::const_iterator idigi = ds.data.begin(), idigiEnd = ds.data.end();
60  idigi != idigiEnd; ++idigi )
61  {
62  TEvePointSet* pointSet = new TEvePointSet;
63  pointSet->SetMarkerSize( 2 );
64  pointSet->SetMarkerStyle( 2 );
65  setupAddElement( pointSet, product );
66 
67  if( ! geom->contains( id ))
68  {
70  << "failed get geometry of SiPixelDigi with detid: "
71  << id << std::endl;
72  }
73  else
74  {
75  float localPoint[3] = {
76  fireworks::pixelLocalX(( *idigi ).row(), pars[0] ),
77  fireworks::pixelLocalY(( *idigi ).column(), pars[1] ),
78  0.0 };
79 
80  float globalPoint[3];
81  geom->localToGlobal( id, localPoint, globalPoint );
82 
83  pointSet->SetNextPoint( globalPoint[0], globalPoint[1], globalPoint[2] );
84  }
85  } // end of iteration over digis in range
86  } // end of iteration over the DetSetVector
87 }
88 
89 
#define REGISTER_FWPROXYBUILDER(_name_, _type_, _purpose_, _view_)
static const int kAllRPZBits
Definition: FWViewType.h:58
float pixelLocalY(const double mpy, const int m_ncols)
Definition: TrackUtils.cc:197
const float * getParameters(unsigned int id) const
Definition: FWGeometry.cc:293
void setupAddElement(TEveElement *el, TEveElement *parent, bool set_color=true) const
void get(const T *&oData) const
Definition: FWEventItem.h:84
static const int kAll3DBits
Definition: FWViewType.h:59
void localToGlobal(unsigned int id, const float *local, float *global, bool translatep=true) const
Definition: FWGeometry.cc:325
bool contains(unsigned int id) const
Definition: FWGeometry.h:98
#define end
Definition: vmac.h:37
iterator end()
Return the off-the-end iterator.
Definition: DetSetVector.h:356
#define fwLog(_level_)
Definition: fwLog.h:50
collection_type data
Definition: DetSet.h:78
det_id_type id
Definition: DetSet.h:77
iterator begin()
Return an iterator to the first DetSet.
Definition: DetSetVector.h:341
collection_type::const_iterator const_iterator
Definition: DetSet.h:33
collection_type::const_iterator const_iterator
Definition: DetSetVector.h:106
float pixelLocalX(const double mpx, const int m_nrows)
Definition: TrackUtils.cc:164
const FWGeometry * getGeom() const
Definition: FWEventItem.cc:681
const FWSiPixelDigiProxyBuilder & operator=(const FWSiPixelDigiProxyBuilder &)