FWTauProxyBuilderBase

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 73 74 75 76 77 78 79
#ifndef Fireworks_Calo_FWTauProxyBuilderBase_h
#define Fireworks_Calo_FWTauProxyBuilderBase_h

// -*- C++ -*-
//
// Package:     Calo
// Class  :     FWTauProxyBuilderBase
//
/**\class FWTauProxyBuilderBase FWTauProxyBuilderBase.h Fireworks/Calo/interface/FWTauProxyBuilderBase.h

 Description: [one line class summary]

 Usage:
    <usage>

*/
//
// Original Author:  Alja Mrak-Tadel
//         Created:  Thu Oct 21 20:40:32 CEST 2010
//

#include "Fireworks/Core/interface/FWProxyBuilderBase.h"
#include "Fireworks/Core/interface/FWViewType.h"
#include "Fireworks/Calo/interface/scaleMarker.h"
#include <vector>

class TEveScalableStraightLineSet;
class FWViewContext;

namespace reco {
  class Jet;
  class BaseTau;
}  // namespace reco

namespace fireworks {
  class Context;
}

class FWTauProxyBuilderBase : public FWProxyBuilderBase {
public:
  FWTauProxyBuilderBase();
  ~FWTauProxyBuilderBase() override;

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

  void setItem(const FWEventItem* iItem) override;

protected:
  float m_minTheta;
  float m_maxTheta;
  std::vector<double> m_phis;
  void buildBaseTau(const reco::BaseTau& iTau,
                    const reco::Jet* iJet,
                    TEveElement* comp,
                    FWViewType::EType type,
                    const FWViewContext* vc);

  void localModelChanges(const FWModelId& iId,
                         TEveElement* iCompound,
                         FWViewType::EType viewType,
                         const FWViewContext* vc) override;

public:
  FWTauProxyBuilderBase(const FWTauProxyBuilderBase&) = delete;  // stop default

  const FWTauProxyBuilderBase& operator=(const FWTauProxyBuilderBase&) = delete;  // stop default
private:
  // ---------- member data --------------------------------
  // Add Tracks which passed quality cuts and
  // are inside a tracker signal cone around leading Track
  void addConstituentTracks(const reco::BaseTau& tau, class TEveElement* product);
  // Add leading Track
  void addLeadTrack(const reco::BaseTau& tau, class TEveElement* product);
};

#endif