ROOT logo
// @(#)root/geom:$Id: TGeoAtt.h 21425 2007-12-17 15:59:27Z brun $
// Author: Andrei Gheata   01/11/01

/*************************************************************************
 * Copyright (C) 1995-2000, Rene Brun and Fons Rademakers.               *
 * All rights reserved.                                                  *
 *                                                                       *
 * For the licensing terms see $ROOTSYS/LICENSE.                         *
 * For the list of contributors see $ROOTSYS/README/CREDITS.             *
 *************************************************************************/

#ifndef ROOT_TGeoAtt
#define ROOT_TGeoAtt

#ifndef ROOT_TObject
#include "TObject.h"
#endif

////////////////////////////////////////////////////////////////////////////
//                                                                        //
// TGeoAtt - visualization and tracking attributes for volumes and nodes  //
//                                                                        //
////////////////////////////////////////////////////////////////////////////

class TGeoAtt
{
public:
  enum {
      kBitMask          = 0x00ffffff        // bit mask
   };

   enum EGeoVisibilityAtt {
      kVisOverride      = BIT(0),           // volume's vis. attributes are overidden
      kVisNone          = BIT(1),           // the volume/node is invisible, as well as daughters
      kVisThis          = BIT(2),           // this volume/node is visible
      kVisDaughters     = BIT(3),           // all leaves are visible
      kVisOneLevel      = BIT(4),           // first level daughters are visible
      kVisStreamed      = BIT(5),           // true if attributes have been streamed
      kVisTouched       = BIT(6),           // true if attributes are changed after closing geom
      kVisOnScreen      = BIT(7),           // true if volume is visible on screen
      kVisContainers    = BIT(12),          // all containers visible
      kVisOnly          = BIT(13),          // just this visible
      kVisBranch        = BIT(14),          // only a given branch visible
      kVisRaytrace      = BIT(15)           // raytracing flag
   };                          // visibility attributes

   enum EGeoActivityAtt   {
      kActOverride      = BIT(8),           // volume's activity attributes are overidden
      kActNone          = BIT(9),           // the volume/node is ignored by tracking, as well as daughters
      kActThis          = BIT(10),           // this volume/node is active for tracking
      kActDaughters     = BIT(11)            // all leaves are active
   };                          // activity flags

   enum EGeoOptimizationAtt {
      kUseBoundingBox   = BIT(16),           // use bounding box for tracking
      kUseVoxels        = BIT(17),           // compute and use voxels
      kUseGsord         = BIT(18)            // use slicing in G3 style     
   };                          // tracking optimization attributes
   enum EGeoSavePrimitiveAtt {
      kSavePrimitiveAtt = BIT(19),
      kSaveNodesAtt     = BIT(20)
   };                          // save primitive bits                          
protected :
// data members
   UInt_t                fGeoAtt;            // option flags
public:
   // constructors
   TGeoAtt();
   TGeoAtt(Option_t *vis_opt, Option_t *activity_opt="", Option_t *optimization_opt="");
   // destructor
   virtual ~TGeoAtt();
   // methods
   void                SetAttBit(UInt_t f)   {fGeoAtt |= f & kBitMask;}
   void                SetAttBit(UInt_t f, Bool_t set) {(set)?SetAttBit(f):ResetAttBit(f);};
   void                ResetAttBit(UInt_t f) {fGeoAtt &= ~(f & kBitMask);}
   Bool_t              TestAttBit(UInt_t f) const {return (Bool_t)((fGeoAtt & f) != 0);}

   void                SetVisRaytrace(Bool_t flag=kTRUE) {SetAttBit(kVisRaytrace, flag);}
   void                SetVisBranch(); 
   virtual void        SetVisContainers(Bool_t flag=kTRUE);
   virtual void        SetVisLeaves(Bool_t flag=kTRUE);
   virtual void        SetVisOnly(Bool_t flag=kTRUE);
   virtual void        SetVisibility(Bool_t vis=kTRUE);
   void                SetVisDaughters(Bool_t vis=kTRUE);
   void                SetVisStreamed(Bool_t vis=kTRUE);
   void                SetVisTouched(Bool_t vis=kTRUE);
   void                SetActivity(Bool_t flag=kTRUE) {SetAttBit(kActThis, flag);}
   void                SetActiveDaughters(Bool_t flag=kTRUE) {SetAttBit(kActDaughters,flag);}
   
   void                SetOptimization(Option_t *option);

   
   Bool_t              IsActive() const {return TestAttBit(kActThis);}
   Bool_t              IsActiveDaughters() const {return TestAttBit(kActDaughters);}
   Bool_t              IsVisRaytrace() const {return TestAttBit(kVisRaytrace);}
   Bool_t              IsVisible() const {return TestAttBit(kVisThis);}
   Bool_t              IsVisDaughters() const {return TestAttBit(kVisDaughters);}
   Bool_t              IsVisBranch() const {return TestAttBit(kVisBranch);}
   Bool_t              IsVisContainers() const {return TestAttBit(kVisContainers);}
   Bool_t              IsVisLeaves() const {return !TestAttBit(kVisContainers | kVisOnly | kVisBranch);}
   Bool_t              IsVisOnly() const {return TestAttBit(kVisOnly);}
   
   Bool_t              IsVisStreamed() const {return TestAttBit(kVisStreamed);}
   Bool_t              IsVisTouched() const {return TestAttBit(kVisTouched);}

   ClassDef(TGeoAtt, 1)         // class for visibility, activity and optimization attributes for volumes/nodes
};

#endif

 TGeoAtt.h:1
 TGeoAtt.h:2
 TGeoAtt.h:3
 TGeoAtt.h:4
 TGeoAtt.h:5
 TGeoAtt.h:6
 TGeoAtt.h:7
 TGeoAtt.h:8
 TGeoAtt.h:9
 TGeoAtt.h:10
 TGeoAtt.h:11
 TGeoAtt.h:12
 TGeoAtt.h:13
 TGeoAtt.h:14
 TGeoAtt.h:15
 TGeoAtt.h:16
 TGeoAtt.h:17
 TGeoAtt.h:18
 TGeoAtt.h:19
 TGeoAtt.h:20
 TGeoAtt.h:21
 TGeoAtt.h:22
 TGeoAtt.h:23
 TGeoAtt.h:24
 TGeoAtt.h:25
 TGeoAtt.h:26
 TGeoAtt.h:27
 TGeoAtt.h:28
 TGeoAtt.h:29
 TGeoAtt.h:30
 TGeoAtt.h:31
 TGeoAtt.h:32
 TGeoAtt.h:33
 TGeoAtt.h:34
 TGeoAtt.h:35
 TGeoAtt.h:36
 TGeoAtt.h:37
 TGeoAtt.h:38
 TGeoAtt.h:39
 TGeoAtt.h:40
 TGeoAtt.h:41
 TGeoAtt.h:42
 TGeoAtt.h:43
 TGeoAtt.h:44
 TGeoAtt.h:45
 TGeoAtt.h:46
 TGeoAtt.h:47
 TGeoAtt.h:48
 TGeoAtt.h:49
 TGeoAtt.h:50
 TGeoAtt.h:51
 TGeoAtt.h:52
 TGeoAtt.h:53
 TGeoAtt.h:54
 TGeoAtt.h:55
 TGeoAtt.h:56
 TGeoAtt.h:57
 TGeoAtt.h:58
 TGeoAtt.h:59
 TGeoAtt.h:60
 TGeoAtt.h:61
 TGeoAtt.h:62
 TGeoAtt.h:63
 TGeoAtt.h:64
 TGeoAtt.h:65
 TGeoAtt.h:66
 TGeoAtt.h:67
 TGeoAtt.h:68
 TGeoAtt.h:69
 TGeoAtt.h:70
 TGeoAtt.h:71
 TGeoAtt.h:72
 TGeoAtt.h:73
 TGeoAtt.h:74
 TGeoAtt.h:75
 TGeoAtt.h:76
 TGeoAtt.h:77
 TGeoAtt.h:78
 TGeoAtt.h:79
 TGeoAtt.h:80
 TGeoAtt.h:81
 TGeoAtt.h:82
 TGeoAtt.h:83
 TGeoAtt.h:84
 TGeoAtt.h:85
 TGeoAtt.h:86
 TGeoAtt.h:87
 TGeoAtt.h:88
 TGeoAtt.h:89
 TGeoAtt.h:90
 TGeoAtt.h:91
 TGeoAtt.h:92
 TGeoAtt.h:93
 TGeoAtt.h:94
 TGeoAtt.h:95
 TGeoAtt.h:96
 TGeoAtt.h:97
 TGeoAtt.h:98
 TGeoAtt.h:99
 TGeoAtt.h:100
 TGeoAtt.h:101
 TGeoAtt.h:102
 TGeoAtt.h:103
 TGeoAtt.h:104
 TGeoAtt.h:105
 TGeoAtt.h:106
 TGeoAtt.h:107
 TGeoAtt.h:108
 TGeoAtt.h:109
 TGeoAtt.h:110