Skip to content
Snippets Groups Projects
gdml_root.C 5.19 KiB
Newer Older
// $Id:$
//====================================================================
//  AIDA Detector description implementation for LCD
//--------------------------------------------------------------------
//
//  Standalone ROOT script to load geometries from DD4hep:
//
//  Full GDML cycle can be tested (deplace <detector> with some meaningful identifier):
//   a) Extract gdml information
//      $ > geoConverter -compact2gdml -input file:<compact-input-xml-file> -output <detector>.gdml
//   b) Extract visualisation hints to csv file
//      $ > geoConverter -compact2vis -input file:<compact-input-xml-file> -output <detector>.vis.csv -ascii
//   c) Load GDML into ROOT (as AClick, but can also be interpreted):
//      $ > root.exe ../doc/gdml_root.C+\(\"<detector>\"\)
//      The macro expects *at least* the <detector>.gdml file. If no visualisation
//      information is found, the resulting graphics however is not very nice!
//
//
//  Author     : M.Frank
//
//====================================================================
// C/C++ include files
Markus Frank's avatar
Markus Frank committed
#include <fstream>
#include <cerrno>
#include <string>
#include <sstream>

// ROOT include files
Markus Frank's avatar
Markus Frank committed
#include <TGeoManager.h>
#include <TColor.h>
#include <TObjArray.h>
#include <TGeoVolume.h>
#include <TGDMLParse.h>

using namespace std;

TGeoVolume* gdml_root(const char* sys_name) {
  bool         debug_processing = false;
Markus Frank's avatar
Markus Frank committed
  TGeoManager* geo = new TGeoManager();
  string       system    = sys_name;
  string       gdml_file = system+".gdml";
  string       vis_file  = system+".vis.csv";
  ifstream     in(vis_file.c_str());
  TGDMLParse   parse;
Markus Frank's avatar
Markus Frank committed
  gDebug = 2;
Markus Frank's avatar
Markus Frank committed
  cout << "++ Processing gdml file:" << gdml_file << endl;

  TGeoVolume* top_vol = parse.GDMLReadFile(gdml_file.c_str());
  TObjArray*  vols    = gGeoManager->GetListOfVolumes();
  int num_volumes = vols->GetEntries();
Markus Frank's avatar
Markus Frank committed

  if ( !in.good() )
    cout << "++ Failed to open visualization file:" << vis_file 
Markus Frank's avatar
Markus Frank committed
         << " :: " << strerror(errno) << endl;
Markus Frank's avatar
Markus Frank committed
  else
    cout << "++ Processing visualization file:" << vis_file << endl;

  while(in.good() ) {
    stringstream debug;
    char         text[1024], *line;
    const char*  vol_name="";
    float        red = 0, blue = 0, green = 0;
    bool         visible = false, show_daughters = false;
    string       line_style="solid", drawing_style="solid";
Markus Frank's avatar
Markus Frank committed

    in.getline(text,sizeof(text),'\n');
    line = strtok(text,";");
    debug << "+ Process:";
    for(int count=0; line != 0; ++count, line=::strtok(0,";"))  {
      debug << line << " ";
      switch(count) {
      case 0:
Markus Frank's avatar
Markus Frank committed
        vol_name = line+::strlen("vol:");
        break;
Markus Frank's avatar
Markus Frank committed
      case 1:
Markus Frank's avatar
Markus Frank committed
        break;
Markus Frank's avatar
Markus Frank committed
      case 2:
Markus Frank's avatar
Markus Frank committed
        line += ::strlen("visible:");
        visible = *line=='1';
        break;
Markus Frank's avatar
Markus Frank committed
      case 3:
Markus Frank's avatar
Markus Frank committed
        line += ::strlen("r:");
        red = atof(line);
        break;
Markus Frank's avatar
Markus Frank committed
      case 4:
Markus Frank's avatar
Markus Frank committed
        line += ::strlen("g:");
        green = atof(line);
        break;
Markus Frank's avatar
Markus Frank committed
      case 5:
Markus Frank's avatar
Markus Frank committed
        line += ::strlen("b:");
        blue = atof(line);
        break;
Markus Frank's avatar
Markus Frank committed
      case 6:
Markus Frank's avatar
Markus Frank committed
        line += ::strlen("alpha:");
        //alpha = atof(line);
        break;
Markus Frank's avatar
Markus Frank committed
      case 7:
Markus Frank's avatar
Markus Frank committed
        line_style = line+::strlen("line_style:");
        break;
Markus Frank's avatar
Markus Frank committed
      case 8:
Markus Frank's avatar
Markus Frank committed
        drawing_style = line+::strlen("drawing_style:");
        break;
Markus Frank's avatar
Markus Frank committed
      case 9:
Markus Frank's avatar
Markus Frank committed
        line += ::strlen("show_daughters:");
        show_daughters = *line=='1';
        break;
Markus Frank's avatar
Markus Frank committed
      default:
Markus Frank's avatar
Markus Frank committed
        break;
Markus Frank's avatar
Markus Frank committed
      }
    }
    if ( debug_processing ) cout << debug.str() << endl;
    debug.str("");

    if ( vol_name && ::strlen(vol_name) )   {
Markus Frank's avatar
Markus Frank committed
      TGeoVolume* volume = 0;
      for(int i=0;i<num_volumes;++i) {
Markus Frank's avatar
Markus Frank committed
        TGeoVolume* v=(TGeoVolume*)vols->At(i);
        if ( 0 == ::strcmp(vol_name,v->GetName()) ) {
          volume = v;
          break;
        }
      }
      if ( volume ) {
Markus Frank's avatar
Markus Frank committed
        int     color  = TColor::GetColor(red,green,blue);
        Color_t bright = TColor::GetColorBright(color);
        Color_t dark   = TColor::GetColorDark(color);
        debug << "+ \tr:" << red << " g:" << green << " b:" << blue << " col:" << color 
              << " line_style:" << line_style << " drawing_style:" << drawing_style 
              << " visible:" << visible << " show_daughters:" << show_daughters;
        volume->SetLineColor(dark);
        if ( drawing_style == "solid" )  {
          volume->SetFillColor(bright);
          volume->SetFillStyle(1001); // Root: solid
        }
        else {
          //volume->SetFillColor(bright);
          volume->SetFillColor(0);
          volume->SetFillStyle(0);    // Root: hollow
        }
        if ( line_style == "unbroken" )
          volume->SetFillStyle(1);
        else
          volume->SetFillStyle(2);
Markus Frank's avatar
Markus Frank committed
        volume->SetLineWidth(10);
        volume->SetVisibility(visible ? kTRUE : kFALSE);
        volume->SetAttBit(TGeoAtt::kVisContainers,kTRUE);
        volume->SetVisDaughters(show_daughters ? kTRUE : kFALSE);
Markus Frank's avatar
Markus Frank committed
      }
      else {
Markus Frank's avatar
Markus Frank committed
        cout << endl << "++ Failed to find volume with name:" << vol_name;
Markus Frank's avatar
Markus Frank committed
      }
    }
    if ( debug_processing ) cout << debug.str() << endl;
  }
Markus Frank's avatar
Markus Frank committed
  cout << "++ Closing geometry and starting display.... Top volume:" << (void*)top_vol << endl;
Markus Frank's avatar
Markus Frank committed
  geo->SetTopVolume(top_vol);
  geo->CloseGeometry();
  geo->SetVisLevel(4);
  geo->SetVisOption(1);
  top_vol->Draw("ogl");
  return top_vol;
}