FWPhase2TrackerCluster1DDetProxyBuilder

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
// -*- C++ -*-
//
// Package:     Tracks
// Class  :     FWPhase2TrackerCluster1DDetProxyBuilder
//
//

#include "TEveGeoNode.h"
#include "TEveGeoShape.h"
#include "Fireworks/Core/interface/FWProxyBuilderBase.h"
#include "Fireworks/Core/interface/FWEventItem.h"
#include "Fireworks/Core/interface/FWGeometry.h"

#include "DataFormats/Phase2TrackerCluster/interface/Phase2TrackerCluster1D.h"
#include "DataFormats/DetId/interface/DetId.h"

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

  REGISTER_PROXYBUILDER_METHODS();

private:
  using FWProxyBuilderBase::build;
  void build(const FWEventItem* iItem, TEveElementList* product, const FWViewContext*) override;

public:
  FWPhase2TrackerCluster1DDetProxyBuilder(const FWPhase2TrackerCluster1DDetProxyBuilder&) = delete;
  const FWPhase2TrackerCluster1DDetProxyBuilder& operator=(const FWPhase2TrackerCluster1DDetProxyBuilder&) = delete;
};

void FWPhase2TrackerCluster1DDetProxyBuilder::build(const FWEventItem* iItem,
                                                    TEveElementList* product,
                                                    const FWViewContext*) {
  const Phase2TrackerCluster1DCollectionNew* pixels = nullptr;

  iItem->get(pixels);

  if (!pixels)
    return;

  const FWGeometry* geom = iItem->getGeom();

  for (Phase2TrackerCluster1DCollectionNew::const_iterator set = pixels->begin(), setEnd = pixels->end(); set != setEnd;
       ++set) {
    unsigned int id = set->detId();
    DetId detid(id);

    if (geom->contains(detid)) {
      const edmNew::DetSet<Phase2TrackerCluster1D>& clusters = *set;

      for (edmNew::DetSet<Phase2TrackerCluster1D>::const_iterator itc = clusters.begin(), edc = clusters.end();
           itc != edc;
           ++itc) {
        TEveGeoShape* shape = geom->getEveShape(detid);

        if (shape) {
          shape->SetMainTransparency(50);
          setupAddElement(shape, product);
        }
      }
    }
  }
}

REGISTER_FWPROXYBUILDER(FWPhase2TrackerCluster1DDetProxyBuilder,
                        Phase2TrackerCluster1DCollectionNew,
                        "Phase2TrackerCluster1DDets",
                        FWViewType::kAll3DBits | FWViewType::kAllRPZBits);