FWZDCRecHitProxyBuilder

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
/*
 *  FWZDCRecHitProxyBuilder.cc
 *  cmsShow
 *
 *  Created by Ianna Osborne on 7/8/10.
 *
 */
#include "Fireworks/Calo/plugins/FWCaloRecHitDigitSetProxyBuilder.h"
#include "DataFormats/HcalRecHit/interface/ZDCRecHit.h"
#include "DataFormats/Common/interface/SortedCollection.h"

class FWZDCRecHitProxyBuilder : public FWCaloRecHitDigitSetProxyBuilder {
public:
  FWZDCRecHitProxyBuilder(void) {}
  ~FWZDCRecHitProxyBuilder(void) override {}

  REGISTER_PROXYBUILDER_METHODS();

  FWZDCRecHitProxyBuilder(const FWZDCRecHitProxyBuilder&) = delete;
  const FWZDCRecHitProxyBuilder& operator=(const FWZDCRecHitProxyBuilder&) = delete;
};

REGISTER_FWPROXYBUILDER(FWZDCRecHitProxyBuilder, edm::SortedCollection<ZDCRecHit>, "ZDC RecHit", FWViewType::kISpyBit);

// AMT scale box round center. Scaling and e/et mode added now. Previusly used energyTower3DCorners().

/*
void FWZDCRecHitProxyBuilder::build(const FWEventItem* iItem, TEveElementList* product, const FWViewContext*)
{
   const edm::SortedCollection<ZDCRecHit> *collection = 0;
   iItem->get( collection );
   if (! collection)
      return;


   TEveBoxSet* boxSet = addBoxSetToProduct(product);
   boxSet->SetAntiFlick(kTRUE);
   int index = 0;
   for (std::vector<ZDCRecHit>::const_iterator it = collection->begin() ; it != collection->end(); ++it)
   {  
      const float* corners = item()->getGeom()->getCorners((*it).detid());

      std::vector<float> scaledCorners(24);
      if (corners != 0) {
         fireworks::energyTower3DCorners(corners, (*it).energy(), scaledCorners);
         // Invert the normals:
         // for (int i = 0; i < 12; ++i)
         //    std::swap(scaledCorners[i], scaledCorners[i+12]);
      }

      addBox(boxSet, &scaledCorners[0], iItem->modelInfo(index++).displayProperties());
   }
   }*/