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 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112
// -*- C++ -*-
//
// Package:     Core
// Class  :     FWGeometryTableViewManager
//
// Implementation:
//     [Notes on implementation]
//
// Original Author:  Alja Mrak-Tadel
//         Created:  Fri Jul  8 00:40:37 CEST 2011
//

#include <functional>
#include <memory>

#include "TFile.h"
#include "TSystem.h"
#include "TGeoManager.h"
#include "TGeoMatrix.h"
#include "TEveManager.h"

#include "Fireworks/Core/interface/FWGeometryTableViewManager.h"
#include "Fireworks/Core/src/FWGeometryTableView.h"
#include "Fireworks/Core/src/FWOverlapTableView.h"
#include "Fireworks/Core/interface/FWGeometry.h"
#include "Fireworks/Core/interface/FWGUIManager.h"
#include "Fireworks/Core/interface/FWColorManager.h"
#include "Fireworks/Core/interface/fwLog.h"

TGeoManager* FWGeometryTableViewManager::s_geoManager = nullptr;

TGeoManager* FWGeometryTableViewManager_GetGeoManager() { return FWGeometryTableViewManager::getGeoMangeur(); }

FWGeometryTableViewManager::FWGeometryTableViewManager(FWGUIManager* iGUIMgr, std::string fileName, std::string geoName)
    : FWViewManagerBase(), m_fileName(fileName), m_TGeoName(geoName) {
  FWGUIManager::ViewBuildFunctor f;
  f = std::bind(&FWGeometryTableViewManager::buildView, this, std::placeholders::_1, std::placeholders::_2);
  iGUIMgr->registerViewBuilder(FWViewType::idToName(FWViewType::kGeometryTable), f);
  iGUIMgr->registerViewBuilder(FWViewType::idToName(FWViewType::kOverlapTable), f);
}

FWGeometryTableViewManager::~FWGeometryTableViewManager() {}

FWViewBase* FWGeometryTableViewManager::buildView(TEveWindowSlot* iParent, const std::string& type) {
  if (!s_geoManager)
    setGeoManagerFromFile();
  std::shared_ptr<FWGeometryTableViewBase> view;

  FWViewType::EType typeId =
      (type == FWViewType::sName[FWViewType::kGeometryTable]) ? FWViewType::kGeometryTable : FWViewType::kOverlapTable;
  if (typeId == FWViewType::kGeometryTable)
    view = std::make_shared<FWGeometryTableView>(iParent, &colorManager());
  else
    view = std::make_shared<FWOverlapTableView>(iParent, &colorManager());

  view->setBackgroundColor();
  m_views.push_back(std::shared_ptr<FWGeometryTableViewBase>(view));
  view->beingDestroyed_.connect(std::bind(&FWGeometryTableViewManager::beingDestroyed, this, std::placeholders::_1));

  return view.get();
}

void FWGeometryTableViewManager::beingDestroyed(const FWViewBase* iView) {
  for (std::vector<std::shared_ptr<FWGeometryTableViewBase> >::iterator it = m_views.begin(); it != m_views.end();
       ++it) {
    if (it->get() == iView) {
      m_views.erase(it);
      return;
    }
  }
}

void FWGeometryTableViewManager::colorsChanged() {
  for (std::vector<std::shared_ptr<FWGeometryTableViewBase> >::iterator it = m_views.begin(); it != m_views.end(); ++it)
    (*it)->setBackgroundColor();
}

//______________________________________________________________________________
TGeoManager* FWGeometryTableViewManager::getGeoMangeur() {
  // Function used in geometry table views.

  assert(s_geoManager);
  return s_geoManager;
}

//______________________________________________________________________________
void FWGeometryTableViewManager::setGeoManagerRuntime(TGeoManager* x) {
  // Function called from FWFFLooper to set geometry created in runtime.

  s_geoManager = x;
}

//______________________________________________________________________________
void FWGeometryTableViewManager::setGeoManagerFromFile() {
  TFile* file = FWGeometry::findFile(m_fileName.c_str());
  fwLog(fwlog::kInfo) << "Geometry table file: " << m_fileName.c_str() << std::endl;
  try {
    if (!file) {
      // Try it as a GDML file
      s_geoManager = TGeoManager::Import(m_fileName.c_str(), m_TGeoName.c_str());
    } else {
      file->ls();
      s_geoManager = (TGeoManager*)file->Get(m_TGeoName.c_str());
    }
    if (!s_geoManager)
      throw std::runtime_error("Can't find TGeoManager object in selected file.");

  } catch (std::runtime_error& e) {
    fwLog(fwlog::kError) << e.what();
    exit(0);
  }
}