FWPFRhoPhiRecHit

Macros

Line Code
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72
#ifndef _FWPFRHOPHIRECHIT_H_
#define _FWPFRHOPHIRECHIT_H_

// -*- C++ -*-
//
// Package:     ParticleFlow
// Class  :     FWPFRhoPhiRecHit
//
// Implementation:
//     <Notes on implementation>
//
// Original Author:  Simon Harris
//

// System include files
#include <cmath>
#include "TEveScalableStraightLineSet.h"
#include "TEveCompound.h"

// User include files
#include "Fireworks/Core/interface/FWProxyBuilderBase.h"
#include "Fireworks/Core/interface/FWViewContext.h"
#include "Fireworks/Core/interface/FWViewEnergyScale.h"

//-----------------------------------------------------------------------------
// FWPFRhoPhiRecHit
//-----------------------------------------------------------------------------
class FWPFRhoPhiRecHit {
public:
  // ---------------- Constructor(s)/Destructor ----------------------
  FWPFRhoPhiRecHit(FWProxyBuilderBase *pb,
                   TEveElement *iH,
                   const FWViewContext *vc,
                   float E,
                   float et,
                   double lPhi,
                   double rPhi,
                   std::vector<TEveVector> &bCorners);
  virtual ~FWPFRhoPhiRecHit();

  // --------------------- Member Functions --------------------------
  void updateScale(TEveScalableStraightLineSet *ls, Double_t scale, unsigned int i);
  void updateScale(const FWViewContext *vc);
  void addChild(FWProxyBuilderBase *pb, TEveElement *itemHolder, const FWViewContext *vc, float E, float et);
  void buildRecHit(FWProxyBuilderBase *pb,
                   TEveElement *itemHolder,
                   const FWViewContext *vc,
                   std::vector<TEveVector> &bCorners);
  void clean();

  // ----------------------Accessor Methods --------------------------
  Double_t getlPhi() { return m_lPhi; }
  TEveScalableStraightLineSet *getLineSet() { return m_ls; }
  void setHasChild(bool b) { m_hasChild = b; }
  void setCorners(int i, TEveVector vec) { m_corners[i] = vec; }

private:
  FWPFRhoPhiRecHit(const FWPFRhoPhiRecHit &);             // Stop default copy constructor
  FWPFRhoPhiRecHit &operator=(const FWPFRhoPhiRecHit &);  // Stop default assignment operator

  // ----------------------- Data Members ----------------------------
  bool m_hasChild;
  float m_energy;
  float m_et;
  Double_t m_lPhi;
  Double_t m_rPhi;
  TEveScalableStraightLineSet *m_ls;
  FWPFRhoPhiRecHit *m_child;
  std::vector<TEveVector> m_corners;
};
#endif
//=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_