Logo ROOT   6.14/05
Reference Guide
TEveScene.cxx
Go to the documentation of this file.
1 // @(#)root/eve:$Id$
2 // Authors: Matevz Tadel & Alja Mrak-Tadel: 2006, 2007
3 
4 /*************************************************************************
5  * Copyright (C) 1995-2007, Rene Brun and Fons Rademakers. *
6  * All rights reserved. *
7  * *
8  * For the licensing terms see $ROOTSYS/LICENSE. *
9  * For the list of contributors see $ROOTSYS/README/CREDITS. *
10  *************************************************************************/
11 
12 #include "TEveScene.h"
13 #include "TEveViewer.h"
14 #include "TEveManager.h"
15 #include "TEveTrans.h"
16 #include "TEvePad.h"
17 
18 #include "TGLScenePad.h"
19 #include "TGLLogicalShape.h"
20 #include "TGLPhysicalShape.h"
21 
22 #include "TList.h"
23 #include "TExMap.h"
24 
25 /** \class TEveScene
26 \ingroup TEve
27 Eve representation of TGLScene.
28 The GLScene is owned by this class - it is created on construction
29 time and deleted at destruction.
30 
31 Normally all objects are positioned directly in global scene-space.
32 By setting the fHierarchical flag, positions of children get
33 calculated by multiplying the transformation matrices of all parents.
34 */
35 
37 
38 ////////////////////////////////////////////////////////////////////////////////
39 /// Constructor.
40 
41 TEveScene::TEveScene(const char* n, const char* t) :
42  TEveElementList(n, t),
43  fPad (0),
44  fGLScene(0),
45  fChanged (kFALSE),
46  fSmartRefresh (kTRUE),
47  fHierarchical (kFALSE)
48 {
49  fPad = new TEvePad;
50  fPad->GetListOfPrimitives()->Add(this);
51  fGLScene = new TGLScenePad(fPad);
52  fGLScene->SetName(n);
55 }
56 
57 ////////////////////////////////////////////////////////////////////////////////
58 /// Constructor.
59 
60 TEveScene::TEveScene(TGLScenePad* gl_scene, const char* n, const char* t) :
61  TEveElementList(n, t),
62  fPad (0),
63  fGLScene(gl_scene),
64  fChanged (kFALSE),
67 {
68  fPad = new TEvePad;
69  fPad->GetListOfPrimitives()->Add(this);
71  fGLScene->SetName(n);
74 }
75 
76 ////////////////////////////////////////////////////////////////////////////////
77 /// Destructor.
78 
80 {
82 
84  gEve->GetScenes()->RemoveElement(this);
85  delete fGLScene;
86  delete fPad;
87 }
88 
89 ////////////////////////////////////////////////////////////////////////////////
90 /// Virtual from TEveElement; here we simply append this scene to
91 /// the list.
92 
94 {
95  scenes.push_back(this);
96 }
97 
98 ////////////////////////////////////////////////////////////////////////////////
99 /// Repaint the scene.
100 
101 void TEveScene::Repaint(Bool_t dropLogicals)
102 {
103  if (dropLogicals) fGLScene->SetSmartRefresh(kFALSE);
105  if (dropLogicals) fGLScene->SetSmartRefresh(kTRUE);
106  fChanged = kFALSE;
107 
108  // Hack to propagate selection state to physical shapes.
109  //
110  // Should actually be published in PadPaint() following a direct
111  // AddObject() call, but would need some other stuff for that.
112  // Optionally, this could be exported via the TAtt3D and everything
113  // would be sweet.
114 
116  TEveElement* elm;
117  for (TGLScene::LogicalShapeMapIt_t li = logs.begin(); li != logs.end(); ++li)
118  {
119  elm = dynamic_cast<TEveElement*>(li->first);
120  if (elm && li->second->Ref() == 1)
121  {
122  TGLPhysicalShape* pshp = const_cast<TGLPhysicalShape*>(li->second->GetFirstPhysical());
123  pshp->Select(elm->GetSelectedLevel());
124  }
125  }
126 
127  // Fix positions for hierarchical scenes.
128  if (fHierarchical)
129  {
131  }
132 }
133 
134 ////////////////////////////////////////////////////////////////////////////////
135 /// Entry point for hierarchical transformation update.
136 /// Calls the recursive variant on all children.
137 
139 {
141 
143 
144  fGLScene->EndUpdate();
145 }
146 
147 ////////////////////////////////////////////////////////////////////////////////
148 /// Set transformation matrix for physical shape of element el in
149 /// the GL-scene and recursively descend into children (if enabled).
150 
152 {
153  static const TEveException eh("TEveScene::RetransHierarchicallyRecurse ");
154 
155  TEveTrans t(tp);
156  if (el->HasMainTrans())
157  t *= el->RefMainTrans();
158 
159  if (el->GetRnrSelf() && el != this)
160  {
162  }
163 
164  if (el->GetRnrChildren())
165  {
166  for (List_i i = el->BeginChildren(); i != el->EndChildren(); ++i)
167  {
168  if ((*i)->GetRnrAnything())
170  }
171  }
172 }
173 
174 ////////////////////////////////////////////////////////////////////////////////
175 /// Set scene's name.
176 
177 void TEveScene::SetName(const char* n)
178 {
180  fGLScene->SetName(n);
181 }
182 
183 ////////////////////////////////////////////////////////////////////////////////
184 /// Paint the scene. Iterate over children and calls PadPaint().
185 
187 {
188  if (GetRnrState())
189  {
190  for(List_i i=fChildren.begin(); i!=fChildren.end(); ++i)
191  (*i)->PadPaint(option);
192  }
193 }
194 
195 ////////////////////////////////////////////////////////////////////////////////
196 /// Remove element from the scene.
197 /// It is not an error if the element is not found in the scene.
198 
200 {
201  static const TEveException eh("TEveScene::DestroyElementRenderers ");
202 
204  Bool_t changed = fGLScene->DestroyLogical(element->GetRenderObject(eh), kFALSE);
205  fGLScene->EndUpdate(changed, changed);
206 }
207 
208 ////////////////////////////////////////////////////////////////////////////////
209 /// Remove element represented by object rnrObj from the scene.
210 /// It is not an error if the element is not found in the scene.
211 
213 {
215  Bool_t changed = fGLScene->DestroyLogical(rnrObj, kFALSE);
216  fGLScene->EndUpdate(changed, changed);
217 }
218 
219 ////////////////////////////////////////////////////////////////////////////////
220 /// Return icon for scene.
221 
223 {
225 }
226 
227 /** \class TEveSceneList
228 \ingroup TEve
229 List of Scenes providing common operations on TEveScene collections.
230 */
231 
233 
234 ////////////////////////////////////////////////////////////////////////////////
235 /// Constructor.
236 
237 TEveSceneList::TEveSceneList(const char* n, const char* t) :
238  TEveElementList(n, t)
239 {
241 }
242 
243 ////////////////////////////////////////////////////////////////////////////////
244 /// Destroy all scenes and their contents.
245 /// Tho object with non-zero deny-destroy will still survive.
246 
248 {
249  List_i i = fChildren.begin();
250  while (i != fChildren.end())
251  {
252  TEveScene* s = (TEveScene*) *(i++);
253  s->DestroyElements();
254  s->DestroyOrWarn();
255  }
256 }
257 
258 ////////////////////////////////////////////////////////////////////////////////
259 /// Repaint scenes that are tagged as changed.
260 
262 {
263  for (List_i i=fChildren.begin(); i!=fChildren.end(); ++i)
264  {
265  TEveScene* s = (TEveScene*) *i;
266  if (s->IsChanged())
267  {
268  s->Repaint(dropLogicals);
269  }
270  }
271 }
272 
273 ////////////////////////////////////////////////////////////////////////////////
274 /// Repaint all scenes.
275 
277 {
278  for (List_i i=fChildren.begin(); i!=fChildren.end(); ++i)
279  {
280  ((TEveScene*) *i)->Repaint(dropLogicals);
281  }
282 }
283 
284 ////////////////////////////////////////////////////////////////////////////////
285 /// Loop over all scenes and remove all instances of element from them.
286 
288 {
289  static const TEveException eh("TEveSceneList::DestroyElementRenderers ");
290 
291  TObject* obj = element->GetRenderObject(eh);
292  for (List_i i=fChildren.begin(); i!=fChildren.end(); ++i)
293  {
294  ((TEveScene*)*i)->DestroyElementRenderers(obj);
295  }
296 }
297 
298 ////////////////////////////////////////////////////////////////////////////////
299 /// Loop over all scenes and update them accordingly:
300 /// 1. if scene is marked as changed, it is repainted;
301 /// 2. otherwise iteration is done over the set of stamped elements and
302 /// their physical/logical shapes are updated accordingly.
303 ///
304 /// This allows much finer update granularity without resetting of
305 /// complex GL-viewer and GL-scene state.
306 
307 void TEveSceneList::ProcessSceneChanges(Bool_t dropLogicals, TExMap* stampMap)
308 {
309  // We need changed elements sorted by their "render object" as we do
310  // parallel iteration over this list and the list of logical shapes
311  // in every scene.
312 
313  static const TEveException eh("TEveSceneList::ProcessSceneChanges ");
314 
315  typedef std::map<TObject*, TEveElement*> mObjectElement_t;
316  typedef mObjectElement_t::iterator mObjectElement_i;
317 
318  mObjectElement_t changed_objects;
319  {
320  Long64_t key, value;
321  TExMapIter stamped_elements(stampMap);
322  while (stamped_elements.Next(key, value))
323  {
324  TEveElement *el = reinterpret_cast<TEveElement*>(key);
325  changed_objects.insert(std::make_pair(el->GetRenderObject(eh), el));
326  }
327  }
328 
329  for (List_i i=fChildren.begin(); i!=fChildren.end(); ++i)
330  {
331  TEveScene* s = (TEveScene*) *i;
332 
333  if (s->IsChanged())
334  {
335  s->Repaint(dropLogicals);
336  }
337  else
338  {
339  Bool_t updateViewers = kFALSE;
340  Bool_t incTimeStamp = kFALSE;
341  Bool_t transbboxChg = kFALSE;
342 
343  s->GetGLScene()->BeginUpdate();
344 
345  // Process stamps.
347  TGLScene::LogicalShapeMapIt_t li = logs.begin();
348 
349  mObjectElement_i ei = changed_objects.begin();
350 
351  while (li != logs.end() && ei != changed_objects.end())
352  {
353  if (li->first == ei->first)
354  {
355  if (li->second->Ref() != 1)
356  Warning("TEveSceneList::ProcessSceneChanges",
357  "Expect one physical, cnt=%u.", li->second->Ref());
358 
359  TGLLogicalShape *lshp = li->second;
360  TGLPhysicalShape *pshp = const_cast<TGLPhysicalShape*>(lshp->GetFirstPhysical());
361  TEveElement *el = ei->second;
362  UChar_t bits = el->GetChangeBits();
363 
364  if (bits & kCBColorSelection)
365  {
366  pshp->Select(el->GetSelectedLevel());
367  pshp->SetDiffuseColor(el->GetMainColor(),
368  el->GetMainTransparency());
369  }
370 
371  if (bits & kCBTransBBox)
372  {
373  if (el->HasMainTrans())
374  pshp->SetTransform(el->PtrMainTrans()->Array());
375  lshp->UpdateBoundingBox();
376  incTimeStamp = kTRUE;
377  transbboxChg = kTRUE;
378  }
379 
380  if (bits & kCBObjProps)
381  {
382  lshp->DLCacheClear();
383  }
384 
385  ++li; ++ei;
386  updateViewers = kTRUE;
387  }
388  else if (li->first < ei->first)
389  {
390  ++li;
391  }
392  else
393  {
394  ++ei;
395  }
396  }
397 
398  s->GetGLScene()->EndUpdate(updateViewers, incTimeStamp, updateViewers);
399 
400  // Fix positions for hierarchical scenes.
401  if (s->GetHierarchical() && transbboxChg)
402  {
404  }
405  }
406  }
407 }
TEveTrans is a 4x4 transformation matrix for homogeneous coordinates stored internally in a column-ma...
Definition: TEveTrans.h:26
List_i EndChildren()
Definition: TEveElement.h:165
virtual void EndUpdate(Bool_t minorChange=kTRUE, Bool_t sceneChanged=kTRUE, Bool_t updateViewers=kTRUE)
Exit scene update mode.
Definition: TGLScene.cxx:1265
virtual void UpdatePhysioLogical(TObject *logid, Double_t *trans, UChar_t *col)
Reposition/recolor physical for given logical (assume TGLObject and a single physical).
Definition: TGLScene.cxx:1352
std::map< TObject *, TGLLogicalShape * > LogicalShapeMap_t
Definition: TGLScene.h:43
long long Long64_t
Definition: RtypesCore.h:69
TList * GetListOfPrimitives() const
Definition: TPad.h:240
Eve representation of TGLScene.
Definition: TEveScene.h:26
virtual Char_t GetMainTransparency() const
Definition: TEveElement.h:279
LogicalShapeMap_t::iterator LogicalShapeMapIt_t
Definition: TGLScene.h:45
virtual Bool_t HasMainTrans() const
Definition: TEveElement.h:285
const char Option_t
Definition: RtypesCore.h:62
void DestroyElementRenderers(TEveElement *element)
Remove element from the scene.
Definition: TEveScene.cxx:199
List_t fChildren
Definition: TEveElement.h:79
void RepaintChangedScenes(Bool_t dropLogicals)
Repaint scenes that are tagged as changed.
Definition: TEveScene.cxx:261
virtual void SetName(const char *name)
Set the name of the TNamed.
Definition: TNamed.cxx:140
void DestroyElementRenderers(TEveElement *element)
Loop over all scenes and remove all instances of element from them.
Definition: TEveScene.cxx:287
static const TGPicture * fgListTreeIcons[9]
Definition: TEveElement.h:63
List_t::iterator List_i
Definition: TEveElement.h:70
Bool_t IsChanged() const
Definition: TEveScene.h:52
virtual Bool_t GetRnrState() const
Definition: TEveElement.h:256
bool Bool_t
Definition: RtypesCore.h:59
void SetAutoDestruct(Bool_t a)
Definition: TGLSceneBase.h:132
void RetransHierarchically()
Entry point for hierarchical transformation update.
Definition: TEveScene.cxx:138
virtual Bool_t GetRnrSelf() const
Definition: TEveElement.h:254
void SetChildClass(TClass *c)
Definition: TEveElement.h:494
A list of TEveElements.
Definition: TEveElement.h:459
Concrete physical shape - a GL drawable.
virtual void RemoveElement(TEveElement *el)
Remove el from the list of children.
virtual TObject * GetRenderObject(const TEveException &eh) const
Definition: TEveElement.h:198
void Class()
Definition: Class.C:29
TGLScenePad * fGLScene
Definition: TEveScene.h:34
virtual void Paint(Option_t *option="")
Paint the scene. Iterate over children and calls PadPaint().
Definition: TEveScene.cxx:186
TEveViewerList * GetViewers() const
Definition: TEveManager.h:145
LogicalShapeMap_t & RefLogicalShapes()
Definition: TGLScene.h:218
virtual Bool_t DestroyLogical(TObject *logid, Bool_t mustFind=kTRUE)
Destroy logical shape defined by unique &#39;ID&#39;.
Definition: TGLScene.cxx:1036
virtual void DestroyElements()
Destroy all children of this element.
virtual Color_t GetMainColor() const
Definition: TEveElement.h:270
Double_t * Array()
Definition: TEveTrans.h:94
void DestroyScenes()
Destroy all scenes and their contents.
Definition: TEveScene.cxx:247
virtual ~TEveScene()
Destructor.
Definition: TEveScene.cxx:79
R__EXTERN TEveManager * gEve
Definition: TEveManager.h:243
Char_t fDestructing
Definition: TEveElement.h:392
TEveSceneList * GetScenes() const
Definition: TEveManager.h:144
virtual Bool_t GetRnrChildren() const
Definition: TEveElement.h:255
Bool_t fSmartRefresh
Definition: TEveScene.h:37
void Select(UChar_t select)
Bool_t fChanged
Definition: TEveScene.h:36
List of Scenes providing common operations on TEveScene collections.
Definition: TEveScene.h:79
Implements VirtualViewer3D interface and fills the base-class visualization structures from pad conte...
Definition: TGLScenePad.h:25
const TGLPhysicalShape * GetFirstPhysical() const
virtual void SetName(const char *name)
Definition: TGLSceneBase.h:83
Abstract logical shape - a GL &#39;drawable&#39; - base for all shapes - faceset sphere etc.
const Bool_t kFALSE
Definition: RtypesCore.h:88
std::list< TEveElement * > List_t
Definition: TEveElement.h:69
virtual void DestroyOrWarn()
Destroy this element. Prints a warning if deny-destroy is in force.
#define ClassImp(name)
Definition: Rtypes.h:359
virtual void SetName(const char *n)
Set scene&#39;s name.
Definition: TEveScene.cxx:177
UChar_t GetChangeBits() const
Definition: TEveElement.h:404
void SetTransform(const TGLMatrix &transform)
TEvePad * fPad
Definition: TEveScene.h:33
virtual void UpdateBoundingBox()
virtual void CollectSceneParents(List_t &scenes)
Virtual from TEveElement; here we simply append this scene to the list.
Definition: TEveScene.cxx:93
static constexpr double s
Mother of all ROOT objects.
Definition: TObject.h:37
void RetransHierarchicallyRecurse(TEveElement *el, const TEveTrans &tp)
Set transformation matrix for physical shape of element el in the GL-scene and recursively descend in...
Definition: TEveScene.cxx:151
This was intended as a TPad wrapper to allow smart updates of groups of pads.
Definition: TEvePad.h:17
TEveSceneList(const TEveSceneList &)
void SceneDestructing(TEveScene *scene)
Callback done from a TEveScene destructor allowing proper removal of the scene from affected viewers...
Definition: TEveViewer.cxx:488
void SetSmartRefresh(Bool_t smart_ref)
Definition: TGLScenePad.h:72
virtual void Add(TObject *obj)
Definition: TList.h:87
virtual void PadPaint(TVirtualPad *pad)
Entry point for updating scene contents via VirtualViewer3D interface.
Bool_t Next(ULong64_t &hash, Long64_t &key, Long64_t &value)
Get next entry from TExMap. Returns kFALSE at end of map.
Definition: TExMap.cxx:411
Bool_t fHierarchical
Definition: TEveScene.h:38
void SetPad(TVirtualPad *p)
Definition: TGLScenePad.h:62
List_i BeginChildren()
Definition: TEveElement.h:164
void Repaint(Bool_t dropLogicals=kFALSE)
Repaint the scene.
Definition: TEveScene.cxx:101
virtual TEveTrans & RefMainTrans()
Return reference to main transformation.
void ProcessSceneChanges(Bool_t dropLogicals, TExMap *stampMap)
Loop over all scenes and update them accordingly:
Definition: TEveScene.cxx:307
Exception class thrown by TEve classes and macros.
Definition: TEveUtil.h:102
TEveScene(const TEveScene &)
void RepaintAllScenes(Bool_t dropLogicals)
Repaint all scenes.
Definition: TEveScene.cxx:276
virtual Bool_t BeginUpdate()
Put scene in update mode, return true if lock acquired.
Definition: TGLScene.cxx:1245
unsigned char UChar_t
Definition: RtypesCore.h:34
virtual TEveTrans * PtrMainTrans(Bool_t create=kTRUE)
Return pointer to main transformation.
virtual UChar_t GetSelectedLevel() const
Get selection level, needed for rendering selection and highlight feedback.
virtual const TGPicture * GetListTreeIcon(Bool_t open=kFALSE)
Return icon for scene.
Definition: TEveScene.cxx:222
TGLScenePad * GetGLScene() const
Definition: TEveScene.h:60
const Bool_t kTRUE
Definition: RtypesCore.h:87
Base class for TEveUtil visualization elements, providing hierarchy management, rendering control and...
Definition: TEveElement.h:33
Bool_t GetHierarchical() const
Definition: TEveScene.h:55
const Int_t n
Definition: legend1.C:16
This class stores a (key,value) pair using an external hash.
Definition: TExMap.h:33
virtual void Warning(const char *method, const char *msgfmt,...) const
Issue warning message.
Definition: TObject.cxx:866
void SetDiffuseColor(const Float_t rgba[4])
Set color from ROOT color index and transparency [0,100].
virtual void DLCacheClear()
Clear all entries for all LODs for this drawable from the display list cache but keeping the reserved...