FWPFCandidateWithHitsProxyBuilder

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
#include "Fireworks/Core/interface/FWProxyBuilderBase.h"
//#include "DataFormats/HcalRecHit/interface/HcalRecHitCollections.h"
#include "DataFormats/ParticleFlowReco/interface/PFRecHit.h"
#include "DataFormats/ParticleFlowReco/interface/PFRecHitFwd.h"
namespace reco {
  class PFCandidate;
  class PFRecHit;
}  // namespace reco
class CaloRecHit;

class FWPFCandidateWithHitsProxyBuilder : public FWProxyBuilderBase {
public:
  FWPFCandidateWithHitsProxyBuilder() {}
  ~FWPFCandidateWithHitsProxyBuilder() override {}

  void build(const FWEventItem* iItem, TEveElementList* product, const FWViewContext*) override;

  bool havePerViewProduct(FWViewType::EType) const override { return true; }

  void scaleProduct(TEveElementList* parent, FWViewType::EType type, const FWViewContext* vc) override;

  REGISTER_PROXYBUILDER_METHODS();

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

private:
  void addHitsForCandidate(const reco::PFCandidate& c, TEveElement* holder, const FWViewContext* vc);
  void initPFRecHitsCollections();
  const reco::PFRecHit* getHitForDetId(unsigned detId);
  void viewContextBoxScale(
      const float* corners, float scale, bool plotEt, std::vector<float>& scaledCorners, const reco::PFRecHit*);

  const reco::PFRecHitCollection* m_collectionHCAL;
};