/usr/include/paraview/vtkSynchronizedRenderers.h is in paraview-dev 5.0.1+dfsg1-4.
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 | /*=========================================================================
Program: Visualization Toolkit
Module: vtkSynchronizedRenderers.h
Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
All rights reserved.
See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
This software is distributed WITHOUT ANY WARRANTY; without even
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
PURPOSE. See the above copyright notice for more information.
=========================================================================*/
// .NAME vtkSynchronizedRenderers - synchronizes renderers across processes.
// .SECTION Description
// vtkSynchronizedRenderers is used to synchronize renderers (vtkRenderer and
// subclasses) across processes for parallel rendering. It's designed to be used
// in conjunction with vtkSynchronizedRenderWindows to synchronize the render
// windows among those processes.
// This class handles synchronization of certain render parameters among the
// renderers such as viewport, camera parameters. It doesn't support compositing
// of rendered images across processes on its own. You typically either subclass
// to implement a compositing algorithm or use a renderer capable of compositing
// eg. IceT based renderer.
#ifndef vtkSynchronizedRenderers_h
#define vtkSynchronizedRenderers_h
#include "vtkRenderingParallelModule.h" // For export macro
#include "vtkObject.h"
#include "vtkUnsignedCharArray.h" // needed for vtkUnsignedCharArray.
#include "vtkSmartPointer.h" // needed for vtkSmartPointer.
class vtkRenderer;
class vtkMultiProcessController;
class vtkMultiProcessStream;
class vtkOpenGLRenderer;
class VTKRENDERINGPARALLEL_EXPORT vtkSynchronizedRenderers : public vtkObject
{
public:
static vtkSynchronizedRenderers* New();
vtkTypeMacro(vtkSynchronizedRenderers, vtkObject);
void PrintSelf(ostream& os, vtkIndent indent);
// Description:
// Set the renderer to be synchronized by this instance. A
// vtkSynchronizedRenderers instance can be used to synchronize exactly 1
// renderer on each processes. You can create multiple instances on
// vtkSynchronizedRenderers to synchronize multiple renderers.
virtual void SetRenderer(vtkRenderer*);
virtual vtkRenderer* GetRenderer();
// Description:
// Set the parallel message communicator. This is used to communicate among
// processes.
virtual void SetParallelController(vtkMultiProcessController*);
vtkGetObjectMacro(ParallelController, vtkMultiProcessController);
// Description:
// Enable/Disable parallel rendering. Unless Parallel rendering is on, the
// cameras won't be synchronized across processes.
vtkSetMacro(ParallelRendering, bool);
vtkGetMacro(ParallelRendering, bool);
vtkBooleanMacro(ParallelRendering, bool);
// Description:
// Get/Set the image reduction factor.
vtkSetClampMacro(ImageReductionFactor, int, 1, 50);
vtkGetMacro(ImageReductionFactor, int);
// Description:
// If on (default), the rendered images are pasted back on to the screen. You
// should turn this flag off on processes that are not meant to be visible to
// the user.
vtkSetMacro(WriteBackImages, bool);
vtkGetMacro(WriteBackImages, bool);
vtkBooleanMacro(WriteBackImages, bool);
// Description:
// Get/Set the root-process id. This is required when the ParallelController
// is a vtkSocketController. Set to 0 by default (which will not work when
// using a vtkSocketController but will work for vtkMPIController).
vtkSetMacro(RootProcessId, int);
vtkGetMacro(RootProcessId, int);
// Description:
// Computes visible prob bounds. This must be called on all processes at the
// same time. The collective result is made available on all processes once
// this method returns.
// Note that this method requires that bounds is initialized to some value.
// This expands the bounds to include the prop bounds.
void CollectiveExpandForVisiblePropBounds(double bounds[6]);
// Description:
// When set, this->CaptureRenderedImage() does not capture image from the
// screen instead passes the call to the delegate.
virtual void SetCaptureDelegate(vtkSynchronizedRenderers*);
vtkGetObjectMacro(CaptureDelegate, vtkSynchronizedRenderers);
// Description:
// When multiple groups of processes are synchronized together using different
// controllers, one needs to specify the order in which the various
// synchronizers execute. In such cases one starts with the outer most
// vtkSynchronizedRenderers, sets the dependent one as a CaptureDelegate on it
// and the turn off AutomaticEventHandling on the delegate.
vtkSetMacro(AutomaticEventHandling, bool);
vtkGetMacro(AutomaticEventHandling, bool);
vtkBooleanMacro(AutomaticEventHandling, bool);
//BTX
enum
{
SYNC_RENDERER_TAG = 15101,
RESET_CAMERA_TAG = 15102,
COMPUTE_BOUNDS_TAG = 15103
};
/// vtkRawImage can be used to make it easier to deal with images for
/// compositing/communicating over client-server etc.
struct VTKRENDERINGPARALLEL_EXPORT vtkRawImage
{
public:
vtkRawImage()
{
this->Valid = false;
this->Size[0] = this->Size[1] = 0;
this->Data = vtkSmartPointer<vtkUnsignedCharArray>::New();
}
void Resize(int dx, int dy, int numcomps)
{
this->Valid = false;
this->Allocate(dx, dy, numcomps);
}
// Description:
// Create the buffer from an image data.
void Initialize(int dx, int dy, vtkUnsignedCharArray* data);
void MarkValid() { this->Valid = true; }
void MarkInValid() { this->Valid = false; }
bool IsValid() { return this->Valid; }
int GetWidth() { return this->Size[0];}
int GetHeight() { return this->Size[1];}
vtkUnsignedCharArray* GetRawPtr()
{ return this->Data; }
// Pushes the image to the viewport.
bool PushToViewport(vtkRenderer*);
// This is a raw version of PushToViewport() that assumes that the
// glViewport() has already been setup externally.
// the argument is optional for backwards compat with old OpenGL
bool PushToFrameBuffer(vtkRenderer *ren = NULL);
// Captures the image from the viewport.
// This doesn't trigger a render, just captures what's currently there in
// the active buffer.
bool Capture(vtkRenderer*);
// Save the image as a png. Useful for debugging.
void SaveAsPNG(const char* filename);
private:
bool Valid;
int Size[2];
vtkSmartPointer<vtkUnsignedCharArray> Data;
void Allocate(int dx, int dy, int numcomps);
};
//ETX
protected:
vtkSynchronizedRenderers();
~vtkSynchronizedRenderers();
struct RendererInfo
{
int ImageReductionFactor;
int Draw;
int CameraParallelProjection;
double Viewport[4];
double CameraPosition[3];
double CameraFocalPoint[3];
double CameraViewUp[3];
double CameraWindowCenter[2];
double CameraClippingRange[2];
double CameraViewAngle;
double CameraParallelScale;
double EyeTransformMatrix[16];
double ModelTransformMatrix[16];
// Save/restore the struct to/from a stream.
void Save(vtkMultiProcessStream& stream);
bool Restore(vtkMultiProcessStream& stream);
void CopyFrom(vtkRenderer*);
void CopyTo(vtkRenderer*);
};
// These methods are called on all processes as a consequence of corresponding
// events being called on the renderer.
virtual void HandleStartRender();
virtual void HandleEndRender();
virtual void HandleAbortRender() {}
virtual void MasterStartRender();
virtual void SlaveStartRender();
virtual void MasterEndRender();
virtual void SlaveEndRender();
vtkMultiProcessController* ParallelController;
vtkOpenGLRenderer* Renderer;
// Description:
// Can be used in HandleEndRender(), MasterEndRender() or SlaveEndRender()
// calls to capture the rendered image. If this->ImageReductionFactor, then
// the image will be capture in this->ReducedImage, otherwise it will be
// captured in this->FullImage (this->ReducedImage will be pointing to the
// same image).
virtual vtkRawImage& CaptureRenderedImage();
// Description:
// Can be used in HandleEndRender(), MasterEndRender() or SlaveEndRender()
// calls to paste back the image from either this->ReducedImage or
// this->FullImage info the viewport.
virtual void PushImageToScreen();
vtkSynchronizedRenderers* CaptureDelegate;
vtkRawImage ReducedImage;
vtkRawImage FullImage;
bool ParallelRendering;
int ImageReductionFactor;
bool WriteBackImages;
int RootProcessId;
bool AutomaticEventHandling;
private:
vtkSynchronizedRenderers(const vtkSynchronizedRenderers&); // Not implemented
void operator=(const vtkSynchronizedRenderers&); // Not implemented
class vtkObserver;
vtkObserver* Observer;
friend class vtkObserver;
double LastViewport[4];
};
#endif
|