/usr/include/root/TGLViewer.h is in libroot-graf3d-gl-dev 5.34.14-1build1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 | // @(#)root/gl:$Id$
// Author: Richard Maunder 25/05/2005
/*************************************************************************
* Copyright (C) 1995-2004, 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_TGLViewer
#define ROOT_TGLViewer
#include "TGLViewerBase.h"
#include "TGLRnrCtx.h"
#include "TGLSelectRecord.h"
#include "TVirtualViewer3D.h"
#include "TBuffer3D.h"
#include "TGLPerspectiveCamera.h"
#include "TGLOrthoCamera.h"
#include "TGLClip.h"
#include "TTimer.h"
#include "TPoint.h"
#include "TGEventHandler.h"
#include "GuiTypes.h"
#include "TQObject.h"
#include <vector>
class TGLSceneBase;
class TGLRedrawTimer;
class TGLViewerEditor;
class TGLWidget;
class TGLLightSet;
class TGLClipSet;
class TGLManipSet;
class TGLCameraOverlay;
class TGLContextIdentity;
class TGLAutoRotator;
class TTimer;
class TContextMenu;
class TGedEditor;
class TGLPShapeObj;
class TGLViewer : public TVirtualViewer3D,
public TGLViewerBase,
public TQObject
{
friend class TGLOutput;
friend class TGLEventHandler;
public:
enum ECameraType { kCameraPerspXOZ, kCameraPerspYOZ, kCameraPerspXOY,
kCameraOrthoXOY, kCameraOrthoXOZ, kCameraOrthoZOY,
kCameraOrthoXnOY, kCameraOrthoXnOZ, kCameraOrthoZnOY };
enum ESecSelType { // When to do secondary-selection:
kOnRequest, // - on request - when Mod1 is pressed or logical-shape requests it;
kOnKeyMod1 // - only when Mod1 is pressed.
};
private:
TGLViewer(const TGLViewer &); // Not implemented
TGLViewer & operator=(const TGLViewer &); // Not implemented
void InitSecondaryObjects();
protected:
// External handles
TVirtualPad *fPad; //! external pad - remove replace with signal
// GUI Handles
TContextMenu *fContextMenu; //!
// Cameras
// TODO: Put in vector and allow external creation
TGLPerspectiveCamera fPerspectiveCameraXOZ; //!
TGLPerspectiveCamera fPerspectiveCameraYOZ; //!
TGLPerspectiveCamera fPerspectiveCameraXOY; //!
TGLOrthoCamera fOrthoXOYCamera; //!
TGLOrthoCamera fOrthoXOZCamera; //!
TGLOrthoCamera fOrthoZOYCamera; //!
TGLOrthoCamera fOrthoXnOYCamera; //!
TGLOrthoCamera fOrthoXnOZCamera; //!
TGLOrthoCamera fOrthoZnOYCamera; //!
TGLCamera *fCurrentCamera; //!
TGLAutoRotator *fAutoRotator; //!
// Stereo
Bool_t fStereo; //! use stereo rendering
Float_t fStereoZeroParallax; //! position of zero-parallax plane: 0 - near clipping plane, 1 - far clipping plane
Float_t fStereoEyeOffsetFac; //!
Float_t fStereoFrustumAsymFac; //!
// Lights
TGLLightSet *fLightSet; //!
// Clipping
TGLClipSet *fClipSet; //!
// Selected physical
TGLSelectRecord fCurrentSelRec; //! select record in use as selected
TGLSelectRecord fSelRec; //! select record from last select (should go to context)
TGLSelectRecord fSecSelRec; //! select record from last secondary select (should go to context)
TGLManipSet *fSelectedPShapeRef; //!
// Overlay
TGLOverlayElement *fCurrentOvlElm; //! current overlay element
TGLOvlSelectRecord fOvlSelRec; //! select record from last overlay select
TGEventHandler *fEventHandler; //! event handler
TGedEditor *fGedEditor; //! GED editor
TGLPShapeObj *fPShapeWrap;
// Mouse ineraction
public:
enum EPushAction { kPushStd,
kPushCamCenter, kPushAnnotate };
enum EDragAction { kDragNone,
kDragCameraRotate, kDragCameraTruck, kDragCameraDolly,
kDragOverlay };
protected:
EPushAction fPushAction;
EDragAction fDragAction;
// Redraw timer
TGLRedrawTimer *fRedrawTimer; //! timer for triggering redraws
Float_t fMaxSceneDrawTimeHQ; //! max time for scene rendering at high LOD (in ms)
Float_t fMaxSceneDrawTimeLQ; //! max time for scene rendering at high LOD (in ms)
TGLRect fViewport; //! viewport - drawn area
TGLColorSet fDarkColorSet; //! color-set with dark background
TGLColorSet fLightColorSet; //! color-set with light background
Float_t fPointScale; //! size scale for points
Float_t fLineScale; //! width scale for lines
Bool_t fSmoothPoints; //! smooth point edge rendering
Bool_t fSmoothLines; //! smooth line edge rendering
Int_t fAxesType; //! axes type
Bool_t fAxesDepthTest; //! remove guides hidden-lines
Bool_t fReferenceOn; //! reference marker on?
TGLVertex3 fReferencePos; //! reference position
Bool_t fDrawCameraCenter; //! reference marker on?
TGLCameraOverlay *fCameraOverlay; //! markup size of viewport in scene units
Bool_t fSmartRefresh; //! cache logicals during scene rebuilds
// Debug tracing (for scene rebuilds)
Bool_t fDebugMode; //! debug mode (forced rebuild + draw scene/frustum/interest boxes)
Bool_t fIsPrinting; //!
TString fPictureFileName; //! default file-name for SavePicture()
Float_t fFader; //! fade the view (0 - no fade/default, 1 - full fade/no rendering done)
static TGLColorSet fgDefaultColorSet; //! a shared, default color-set
static Bool_t fgUseDefaultColorSetForNewViewers; //! name says it all
///////////////////////////////////////////////////////////////////////
// Methods
///////////////////////////////////////////////////////////////////////
virtual void SetupClipObject();
// Drawing - can tidy up/remove lots when TGLManager added
void InitGL();
void PreDraw();
void PostDraw();
void FadeView(Float_t alpha);
void MakeCurrent() const;
void SwapBuffers() const;
// Cameras
void SetViewport(Int_t x, Int_t y, Int_t width, Int_t height);
void SetViewport(const TGLRect& vp);
void SetupCameras(Bool_t reset);
protected:
TGLWidget *fGLWidget;
Int_t fGLDevice; //!for embedded gl viewer
TGLContextIdentity *fGLCtxId; //!for embedded gl viewer
// Updata/camera-reset behaviour
Bool_t fIgnoreSizesOnUpdate; // ignore sizes of bounding-boxes on update
Bool_t fResetCamerasOnUpdate; // reposition camera on each update
Bool_t fResetCamerasOnNextUpdate; // reposition camera on next update
public:
TGLViewer(TVirtualPad* pad, Int_t x, Int_t y, Int_t width, Int_t height);
TGLViewer(TVirtualPad* pad);
virtual ~TGLViewer();
// TVirtualViewer3D interface ... mostly a facade
// Forward to TGLScenePad
virtual Bool_t CanLoopOnPrimitives() const { return kTRUE; }
virtual void PadPaint(TVirtualPad* pad);
// Actually used by GL-in-pad
virtual Int_t DistancetoPrimitive(Int_t px, Int_t py);
virtual void ExecuteEvent(Int_t event, Int_t px, Int_t py);
// Only implemented because they're abstract ... should throw an
// exception or assert they are not called.
virtual Bool_t PreferLocalFrame() const { return kTRUE; }
virtual void BeginScene() {}
virtual Bool_t BuildingScene() const { return kFALSE; }
virtual void EndScene() {}
virtual Int_t AddObject(const TBuffer3D&, Bool_t* = 0) { return TBuffer3D::kNone; }
virtual Int_t AddObject(UInt_t, const TBuffer3D&, Bool_t* = 0) { return TBuffer3D::kNone; }
virtual Bool_t OpenComposite(const TBuffer3D&, Bool_t* = 0) { return kFALSE; }
virtual void CloseComposite() {}
virtual void AddCompositeOp(UInt_t) {}
virtual void PrintObjects();
virtual void ResetCameras() { SetupCameras(kTRUE); }
virtual void ResetCamerasAfterNextUpdate() { fResetCamerasOnNextUpdate = kTRUE; }
TGLWidget* GetGLWidget() { return fGLWidget; }
virtual void CreateGLWidget() {}
virtual void DestroyGLWidget() {}
Int_t GetDev() const { return fGLDevice; }
Bool_t GetSmartRefresh() const { return fSmartRefresh; }
void SetSmartRefresh(Bool_t smart_ref) { fSmartRefresh = smart_ref; }
TGLColorSet& RefDarkColorSet() { return fDarkColorSet; }
TGLColorSet& RefLightColorSet() { return fLightColorSet; }
TGLColorSet& ColorSet() { return * fRnrCtx->GetBaseColorSet(); }
void UseDarkColorSet();
void UseLightColorSet();
void SwitchColorSet();
void UseDefaultColorSet(Bool_t x);
Bool_t IsUsingDefaultColorSet() const;
Bool_t IsColorSetDark() const;
void SetClearColor(Color_t col);
static TGLColorSet& GetDefaultColorSet();
static void UseDefaultColorSetForNewViewers(Bool_t x);
static Bool_t IsUsingDefaultColorSetForNewViewers();
const TGLRect& RefViewport() const { return fViewport; }
Int_t ViewportDiagonal() const { return fViewport.Diagonal(); }
Float_t GetPointScale() const { return fPointScale; }
Float_t GetLineScale() const { return fLineScale; }
void SetPointScale(Float_t s) { fPointScale = s; }
void SetLineScale (Float_t s) { fLineScale = s; }
Bool_t GetSmoothPoints() const { return fSmoothPoints; }
Bool_t GetSmoothLines() const { return fSmoothLines; }
void SetSmoothPoints(Bool_t s){ fSmoothPoints = s; }
void SetSmoothLines(Bool_t s) { fSmoothLines = s; }
TGLLightSet* GetLightSet() const { return fLightSet; }
TGLClipSet * GetClipSet() const { return fClipSet; }
Bool_t GetClipAutoUpdate() const { return fClipSet->GetAutoUpdate(); }
void SetClipAutoUpdate(Bool_t x) { fClipSet->SetAutoUpdate(x); }
// External GUI component interface
TGLCamera & CurrentCamera() const { return *fCurrentCamera; }
TGLCamera & RefCamera(ECameraType camera);
void SetCurrentCamera(ECameraType camera);
void SetOrthoCamera(ECameraType camera, Double_t zoom, Double_t dolly,
Double_t center[3], Double_t hRotate, Double_t vRotate);
void SetPerspectiveCamera(ECameraType camera, Double_t fov, Double_t dolly,
Double_t center[3], Double_t hRotate, Double_t vRotate);
void ReinitializeCurrentCamera(const TGLVector3& hAxis, const TGLVector3& vAxis, Bool_t redraw=kTRUE);
void GetGuideState(Int_t & axesType, Bool_t & axesDepthTest, Bool_t & referenceOn, Double_t* referencePos) const;
void SetGuideState(Int_t axesType, Bool_t axesDepthTest, Bool_t referenceOn, const Double_t* referencePos);
void SetDrawCameraCenter(Bool_t x);
Bool_t GetDrawCameraCenter() { return fDrawCameraCenter; }
void PickCameraCenter() { fPushAction = kPushCamCenter; RefreshPadEditor(this); }
void PickAnnotate() { fPushAction = kPushAnnotate; RefreshPadEditor(this); }
TGLCameraOverlay* GetCameraOverlay() const { return fCameraOverlay; }
void SetCameraOverlay(TGLCameraOverlay* m) { fCameraOverlay = m; }
TGLAutoRotator* GetAutoRotator();
void SetAutoRotator(TGLAutoRotator* ar);
// Stereo
Bool_t GetStereo() const { return fStereo; }
Float_t GetStereoZeroParallax() const { return fStereoZeroParallax; }
Float_t GetStereoEyeOffsetFac() const { return fStereoEyeOffsetFac; }
Float_t GetStereoFrustumAsymFac() const { return fStereoFrustumAsymFac; }
void SetStereo(Bool_t s) { fStereo = s; }
void SetStereoZeroParallax(Float_t f) { fStereoZeroParallax = f; }
void SetStereoEyeOffsetFac(Float_t f) { fStereoEyeOffsetFac = f; }
void SetStereoFrustumAsymFac(Float_t f) { fStereoFrustumAsymFac = f; }
// Push / drag action
EPushAction GetPushAction() const { return fPushAction; }
EDragAction GetDragAction() const { return fDragAction; }
const TGLPhysicalShape * GetSelected() const;
// Draw and selection
// Scene rendering timeouts
Float_t GetMaxSceneDrawTimeHQ() const { return fMaxSceneDrawTimeHQ; }
Float_t GetMaxSceneDrawTimeLQ() const { return fMaxSceneDrawTimeLQ; }
void SetMaxSceneDrawTimeHQ(Float_t t) { fMaxSceneDrawTimeHQ = t; }
void SetMaxSceneDrawTimeLQ(Float_t t) { fMaxSceneDrawTimeLQ = t; }
// Request methods post cross thread request via TROOT::ProcessLineFast().
void RequestDraw(Short_t LOD = TGLRnrCtx::kLODMed); // Cross thread draw request
virtual void PreRender();
virtual void Render();
virtual void PostRender();
void DoDraw(Bool_t swap_buffers=kTRUE);
void DoDrawMono(Bool_t swap_buffers);
void DoDrawStereo(Bool_t swap_buffers);
void DrawGuides();
void DrawDebugInfo();
Bool_t RequestSelect(Int_t x, Int_t y); // Cross thread select request
Bool_t DoSelect(Int_t x, Int_t y); // First level selecton (shapes/objects).
Bool_t RequestSecondarySelect(Int_t x, Int_t y); // Cross thread secondary select request
Bool_t DoSecondarySelect(Int_t x, Int_t y); // Second level selecton (inner structure).
void ApplySelection();
Bool_t RequestOverlaySelect(Int_t x, Int_t y); // Cross thread select request
Bool_t DoOverlaySelect(Int_t x, Int_t y); // Window coords origin top left
// Saving of screen image
Bool_t SavePicture();
Bool_t SavePicture(const TString &fileName);
Bool_t SavePictureUsingBB (const TString &fileName);
Bool_t SavePictureUsingFBO(const TString &fileName, Int_t w, Int_t h, Float_t pixel_object_scale=0);
Bool_t SavePictureWidth (const TString &fileName, Int_t width, Bool_t pixel_object_scale=kTRUE);
Bool_t SavePictureHeight(const TString &fileName, Int_t height, Bool_t pixel_object_scale=kTRUE);
Bool_t SavePictureScale (const TString &fileName, Float_t scale, Bool_t pixel_object_scale=kTRUE);
const char* GetPictureFileName() const { return fPictureFileName.Data(); }
void SetPictureFileName(const TString& f) { fPictureFileName = f; }
Float_t GetFader() const { return fFader; }
void SetFader(Float_t x) { fFader = x; }
void AutoFade(Float_t fade, Float_t time=1, Int_t steps=10);
// Update/camera-reset
void UpdateScene(Bool_t redraw=kTRUE);
Bool_t GetIgnoreSizesOnUpdate() const { return fIgnoreSizesOnUpdate; }
void SetIgnoreSizesOnUpdate(Bool_t v) { fIgnoreSizesOnUpdate = v; }
void ResetCurrentCamera();
Bool_t GetResetCamerasOnUpdate() const { return fResetCamerasOnUpdate; }
void SetResetCamerasOnUpdate(Bool_t v) { fResetCamerasOnUpdate = v; }
virtual void PostSceneBuildSetup(Bool_t resetCameras);
virtual void Activated() { Emit("Activated()"); } // *SIGNAL*
virtual void MouseIdle(TGLPhysicalShape*,UInt_t,UInt_t); // *SIGNAL*
virtual void MouseOver(TGLPhysicalShape*); // *SIGNAL*
virtual void MouseOver(TGLPhysicalShape*, UInt_t state); // *SIGNAL*
virtual void MouseOver(TObject *obj, UInt_t state); // *SIGNAL*
virtual void ReMouseOver(TObject *obj, UInt_t state); // *SIGNAL*
virtual void UnMouseOver(TObject *obj, UInt_t state); // *SIGNAL*
virtual void Clicked(TObject *obj); //*SIGNAL*
virtual void Clicked(TObject *obj, UInt_t button, UInt_t state); //*SIGNAL*
virtual void ReClicked(TObject *obj, UInt_t button, UInt_t state); //*SIGNAL*
virtual void UnClicked(TObject *obj, UInt_t button, UInt_t state); //*SIGNAL*
virtual void DoubleClicked() { Emit("DoubleClicked()"); } // *SIGNAL*
TGEventHandler *GetEventHandler() const { return fEventHandler; }
virtual void SetEventHandler(TGEventHandler *handler);
TGedEditor* GetGedEditor() const { return fGedEditor; }
virtual void SetGedEditor(TGedEditor* ed) { fGedEditor = ed; }
virtual void SelectionChanged();
virtual void OverlayDragFinished();
virtual void RefreshPadEditor(TObject* obj=0);
virtual void RemoveOverlayElement(TGLOverlayElement* el);
TGLSelectRecord& GetSelRec() { return fSelRec; }
TGLOvlSelectRecord& GetOvlSelRec() { return fOvlSelRec; }
TGLOverlayElement* GetCurrentOvlElm() const { return fCurrentOvlElm; }
void ClearCurrentOvlElm();
ClassDef(TGLViewer,0) // Standard ROOT GL viewer.
};
// TODO: Find a better place/way to do this
class TGLRedrawTimer : public TTimer
{
private:
TGLViewer & fViewer;
Short_t fRedrawLOD;
Bool_t fPending;
public:
TGLRedrawTimer(TGLViewer & viewer) :
fViewer(viewer), fRedrawLOD(TGLRnrCtx::kLODHigh), fPending(kFALSE) {}
~TGLRedrawTimer() {}
void RequestDraw(Int_t milliSec, Short_t redrawLOD)
{
if (fPending) TurnOff(); else fPending = kTRUE;
if (redrawLOD < fRedrawLOD) fRedrawLOD = redrawLOD;
TTimer::Start(milliSec, kTRUE);
}
Bool_t IsPending() const { return fPending; }
virtual void Stop()
{
if (fPending) { TurnOff(); fPending = kFALSE; }
}
Bool_t Notify()
{
TurnOff();
fPending = kFALSE;
fViewer.RequestDraw(fRedrawLOD);
fRedrawLOD = TGLRnrCtx::kLODHigh;
return kTRUE;
}
};
class TGLFaderHelper {
private:
TGLFaderHelper(const TGLFaderHelper&); // Not implemented
TGLFaderHelper& operator=(const TGLFaderHelper&); // Not implemented
public:
TGLViewer *fViewer;
Float_t fFadeTarget;
Float_t fTime;
Int_t fNSteps;
TGLFaderHelper() :
fViewer(0), fFadeTarget(0), fTime(0), fNSteps(0) {}
TGLFaderHelper(TGLViewer* v, Float_t fade, Float_t time, Int_t steps) :
fViewer(v),fFadeTarget(fade), fTime(time), fNSteps(steps) {}
virtual ~TGLFaderHelper() {}
void MakeFadeStep();
ClassDef(TGLFaderHelper, 0);
};
#endif // ROOT_TGLViewer
|