/usr/include/paraview/vtkImageViewer2.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 | /*=========================================================================
Program: Visualization Toolkit
Module: vtkImageViewer2.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 vtkImageViewer2 - Display a 2D image.
// .SECTION Description
// vtkImageViewer2 is a convenience class for displaying a 2D image. It
// packages up the functionality found in vtkRenderWindow, vtkRenderer,
// vtkImageActor and vtkImageMapToWindowLevelColors into a single easy to use
// class. This class also creates an image interactor style
// (vtkInteractorStyleImage) that allows zooming and panning of images, and
// supports interactive window/level operations on the image. Note that
// vtkImageViewer2 is simply a wrapper around these classes.
//
// vtkImageViewer2 uses the 3D rendering and texture mapping engine
// to draw an image on a plane. This allows for rapid rendering,
// zooming, and panning. The image is placed in the 3D scene at a
// depth based on the z-coordinate of the particular image slice. Each
// call to SetSlice() changes the image data (slice) displayed AND
// changes the depth of the displayed slice in the 3D scene. This can
// be controlled by the AutoAdjustCameraClippingRange ivar of the
// InteractorStyle member.
//
// It is possible to mix images and geometry, using the methods:
//
// viewer->SetInputConnection( imageSource->GetOutputPort() );
// // or viewer->SetInputData ( image );
// viewer->GetRenderer()->AddActor( myActor );
//
// This can be used to annotate an image with a PolyData of "edges" or
// or highlight sections of an image or display a 3D isosurface
// with a slice from the volume, etc. Any portions of your geometry
// that are in front of the displayed slice will be visible; any
// portions of your geometry that are behind the displayed slice will
// be obscured. A more general framework (with respect to viewing
// direction) for achieving this effect is provided by the
// vtkImagePlaneWidget .
//
// Note that pressing 'r' will reset the window/level and pressing
// shift+'r' or control+'r' will reset the camera.
//
// .SECTION See Also
// vtkRenderWindow vtkRenderer vtkImageActor vtkImageMapToWindowLevelColors
#ifndef vtkImageViewer2_h
#define vtkImageViewer2_h
#include "vtkInteractionImageModule.h" // For export macro
#include "vtkObject.h"
class vtkAlgorithm;
class vtkAlgorithmOutput;
class vtkImageActor;
class vtkImageData;
class vtkImageMapToWindowLevelColors;
class vtkInformation;
class vtkInteractorStyleImage;
class vtkRenderWindow;
class vtkRenderer;
class vtkRenderWindowInteractor;
class VTKINTERACTIONIMAGE_EXPORT vtkImageViewer2 : public vtkObject
{
public:
static vtkImageViewer2 *New();
vtkTypeMacro(vtkImageViewer2,vtkObject);
void PrintSelf(ostream& os, vtkIndent indent);
// Description:
// Get the name of rendering window.
virtual const char *GetWindowName();
// Description:
// Render the resulting image.
virtual void Render(void);
// Description:
// Set/Get the input image to the viewer.
virtual void SetInputData(vtkImageData *in);
virtual vtkImageData *GetInput();
virtual void SetInputConnection(vtkAlgorithmOutput* input);
// Description:
// Set/get the slice orientation
//BTX
enum
{
SLICE_ORIENTATION_YZ = 0,
SLICE_ORIENTATION_XZ = 1,
SLICE_ORIENTATION_XY = 2
};
//ETX
vtkGetMacro(SliceOrientation, int);
virtual void SetSliceOrientation(int orientation);
virtual void SetSliceOrientationToXY()
{ this->SetSliceOrientation(vtkImageViewer2::SLICE_ORIENTATION_XY); };
virtual void SetSliceOrientationToYZ()
{ this->SetSliceOrientation(vtkImageViewer2::SLICE_ORIENTATION_YZ); };
virtual void SetSliceOrientationToXZ()
{ this->SetSliceOrientation(vtkImageViewer2::SLICE_ORIENTATION_XZ); };
// Description:
// Set/Get the current slice to display (depending on the orientation
// this can be in X, Y or Z).
vtkGetMacro(Slice, int);
virtual void SetSlice(int s);
// Description:
// Update the display extent manually so that the proper slice for the
// given orientation is displayed. It will also try to set a
// reasonable camera clipping range.
// This method is called automatically when the Input is changed, but
// most of the time the input of this class is likely to remain the same,
// i.e. connected to the output of a filter, or an image reader. When the
// input of this filter or reader itself is changed, an error message might
// be displayed since the current display extent is probably outside
// the new whole extent. Calling this method will ensure that the display
// extent is reset properly.
virtual void UpdateDisplayExtent();
// Description:
// Return the minimum and maximum slice values (depending on the orientation
// this can be in X, Y or Z).
virtual int GetSliceMin();
virtual int GetSliceMax();
virtual void GetSliceRange(int range[2])
{ this->GetSliceRange(range[0], range[1]); }
virtual void GetSliceRange(int &min, int &max);
virtual int* GetSliceRange();
// Description:
// Set window and level for mapping pixels to colors.
virtual double GetColorWindow();
virtual double GetColorLevel();
virtual void SetColorWindow(double s);
virtual void SetColorLevel(double s);
// Description:
// These are here when using a Tk window.
virtual void SetDisplayId(void *a);
virtual void SetWindowId(void *a);
virtual void SetParentId(void *a);
// Description:
// Set/Get the position in screen coordinates of the rendering window.
virtual int* GetPosition();
virtual void SetPosition(int a,int b);
virtual void SetPosition(int a[2]) { this->SetPosition(a[0],a[1]); }
// Description:
// Set/Get the size of the window in screen coordinates in pixels.
virtual int* GetSize();
virtual void SetSize(int a, int b);
virtual void SetSize(int a[2]) { this->SetSize(a[0],a[1]); }
// Description:
// Get the internal render window, renderer, image actor, and
// image map instances.
vtkGetObjectMacro(RenderWindow,vtkRenderWindow);
vtkGetObjectMacro(Renderer, vtkRenderer);
vtkGetObjectMacro(ImageActor,vtkImageActor);
vtkGetObjectMacro(WindowLevel,vtkImageMapToWindowLevelColors);
vtkGetObjectMacro(InteractorStyle,vtkInteractorStyleImage);
// Description:
// Set your own renderwindow and renderer
virtual void SetRenderWindow(vtkRenderWindow *arg);
virtual void SetRenderer(vtkRenderer *arg);
// Description:
// Attach an interactor for the internal render window.
virtual void SetupInteractor(vtkRenderWindowInteractor*);
// Description:
// Create a window in memory instead of on the screen. This may not
// be supported for every type of window and on some windows you may
// need to invoke this prior to the first render.
virtual void SetOffScreenRendering(int);
virtual int GetOffScreenRendering();
vtkBooleanMacro(OffScreenRendering,int);
protected:
vtkImageViewer2();
~vtkImageViewer2();
virtual void InstallPipeline();
virtual void UnInstallPipeline();
vtkImageMapToWindowLevelColors *WindowLevel;
vtkRenderWindow *RenderWindow;
vtkRenderer *Renderer;
vtkImageActor *ImageActor;
vtkRenderWindowInteractor *Interactor;
vtkInteractorStyleImage *InteractorStyle;
int SliceOrientation;
int FirstRender;
int Slice;
virtual void UpdateOrientation();
vtkAlgorithm* GetInputAlgorithm();
vtkInformation* GetInputInformation();
friend class vtkImageViewer2Callback;
private:
vtkImageViewer2(const vtkImageViewer2&); // Not implemented.
void operator=(const vtkImageViewer2&); // Not implemented.
};
#endif
|