FWECaloParticleProxyBuilder

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
#include "Fireworks/Core/interface/FWSimpleProxyBuilderTemplate.h"
#include "Fireworks/Core/interface/Context.h"
#include "Fireworks/Core/interface/FWGeometry.h"
#include "SimDataFormats/CaloAnalysis/interface/CaloParticle.h"
#include "SimDataFormats/CaloAnalysis/interface/CaloParticleFwd.h"
#include "SimDataFormats/CaloAnalysis/interface/SimCluster.h"

#include "TEveBoxSet.h"

class FWECaloParticleProxyBuilder : public FWSimpleProxyBuilderTemplate<CaloParticle> {
public:
  FWECaloParticleProxyBuilder(void) {}
  ~FWECaloParticleProxyBuilder(void) override {}

  REGISTER_PROXYBUILDER_METHODS();

  // Disable default copy constructor
  FWECaloParticleProxyBuilder(const FWECaloParticleProxyBuilder &) = delete;
  // Disable default assignment operator
  const FWECaloParticleProxyBuilder &operator=(const FWECaloParticleProxyBuilder &) = delete;

private:
  void build(const CaloParticle &iData, unsigned int iIndex, TEveElement &oItemHolder, const FWViewContext *) override;
};

void FWECaloParticleProxyBuilder::build(const CaloParticle &iData,
                                        unsigned int iIndex,
                                        TEveElement &oItemHolder,
                                        const FWViewContext *) {
  TEveBoxSet *boxset = new TEveBoxSet();
  boxset->UseSingleColor();
  boxset->SetPickable(true);
  boxset->Reset(TEveBoxSet::kBT_FreeBox, true, 64);
  boxset->SetAntiFlick(true);

  for (const auto &c : iData.simClusters()) {
    for (const auto &it : (*c).hits_and_fractions()) {
      if (DetId(it.first).det() != DetId::Detector::Ecal) {
        std::cerr << "this proxy should be used only for ECAL";
        return;
      }

      const float *corners = item()->getGeom()->getCorners(it.first);
      if (corners == nullptr)
        continue;

      boxset->AddBox(corners);
    }
  }

  boxset->RefitPlex();
  boxset->CSCTakeAnyParentAsMaster();
  boxset->CSCApplyMainColorToMatchingChildren();
  boxset->CSCApplyMainTransparencyToMatchingChildren();
  boxset->SetMainColor(item()->modelInfo(iIndex).displayProperties().color());
  boxset->SetMainTransparency(item()->defaultDisplayProperties().transparency());
  oItemHolder.AddElement(boxset);
}

REGISTER_FWPROXYBUILDER(FWECaloParticleProxyBuilder,
                        CaloParticle,
                        "ECaloParticle",
                        FWViewType::kAll3DBits | FWViewType::kAllRPZBits);