FWPFEcalRecHitRPProxyBuilder

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
#ifndef _FWPFECALRECHITRPPROXYBUILDER_H_
#define _FWPFECALRECHITRPPROXYBUILDER_H_

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

// System include files
#include "TEveCompound.h"

// User include files
#include "Fireworks/Core/interface/FWProxyBuilderTemplate.h"
#include "Fireworks/Core/interface/FWEventItem.h"
#include "Fireworks/Core/interface/FWGeometry.h"
#include "Fireworks/Core/interface/Context.h"

#include "DataFormats/EcalRecHit/interface/EcalRecHit.h"
#include "Fireworks/ParticleFlow/interface/FWPFRhoPhiRecHit.h"
#include "Fireworks/ParticleFlow/interface/FWPFGeom.h"
#include "Fireworks/ParticleFlow/interface/FWPFMaths.h"

#include "Fireworks/Core/interface/FWViewContext.h"
#include "Fireworks/Core/interface/FWViewEnergyScale.h"

//-----------------------------------------------------------------------------
// FWPFEcalRecHitRPProxyBuilder
//-----------------------------------------------------------------------------
class FWPFEcalRecHitRPProxyBuilder : public FWProxyBuilderTemplate<EcalRecHit> {
public:
  static std::string typeOfBuilder() { return "simple#"; }

  // ---------------- Constructor(s)/Destructor ----------------------
  FWPFEcalRecHitRPProxyBuilder() {}
  ~FWPFEcalRecHitRPProxyBuilder() override {}

  // --------------------- Member Functions --------------------------
  void build(const FWEventItem *iItem, TEveElementList *product, const FWViewContext *) override;

  bool havePerViewProduct(FWViewType::EType) const override { return true; }
  void scaleProduct(TEveElementList *parent, FWViewType::EType, const FWViewContext *vc) override;
  void cleanLocal() override;

  REGISTER_PROXYBUILDER_METHODS();

  FWPFEcalRecHitRPProxyBuilder(const FWPFEcalRecHitRPProxyBuilder &) = delete;                   // Stop default
  const FWPFEcalRecHitRPProxyBuilder &operator=(const FWPFEcalRecHitRPProxyBuilder &) = delete;  // Stop default

private:
  // --------------------- Member Functions --------------------------
  TEveVector calculateCentre(const float *corners);

  // ----------------------- Data Members ----------------------------
  std::vector<FWPFRhoPhiRecHit *> m_towers;
};
#endif
//=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_=_