/usr/include/vtk-5.8/vtkView.h is in libvtk5-dev 5.8.0-5.
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 | /*=========================================================================
Program: Visualization Toolkit
Module: vtkView.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.
=========================================================================*/
/*-------------------------------------------------------------------------
Copyright 2008 Sandia Corporation.
Under the terms of Contract DE-AC04-94AL85000 with Sandia Corporation,
the U.S. Government retains certain rights in this software.
-------------------------------------------------------------------------*/
// .NAME vtkView - The superclass for all views.
//
// .SECTION Description
// vtkView is the superclass for views. A view is generally an area of an
// application's canvas devoted to displaying one or more VTK data objects.
// Associated representations (subclasses of vtkDataRepresentation) are
// responsible for converting the data into a displayable format. These
// representations are then added to the view.
//
// For views which display only one data object at a time you may set a
// data object or pipeline connection directly on the view itself (e.g.
// vtkGraphLayoutView, vtkLandscapeView, vtkTreeMapView).
// The view will internally create a vtkDataRepresentation for the data.
//
// A view has the concept of linked selection. If the same data is displayed
// in multiple views, their selections may be linked by setting the same
// vtkAnnotationLink on their representations (see vtkDataRepresentation).
#ifndef __vtkView_h
#define __vtkView_h
#include "vtkObject.h"
class vtkAlgorithmOutput;
class vtkCommand;
class vtkDataObject;
class vtkDataRepresentation;
class vtkSelection;
class vtkViewTheme;
class VTK_VIEWS_EXPORT vtkView : public vtkObject
{
public:
static vtkView *New();
vtkTypeMacro(vtkView, vtkObject);
void PrintSelf(ostream& os, vtkIndent indent);
// Description:
// Adds the representation to the view.
void AddRepresentation(vtkDataRepresentation* rep);
// Description:
// Set the representation to the view.
void SetRepresentation(vtkDataRepresentation* rep);
// Description:
// Convenience method which creates a simple representation with the
// connection and adds it to the view.
// Returns the representation internally created.
// NOTE: The returned representation pointer is not reference-counted,
// so you MUST call Register() on the representation if you want to
// keep a reference to it.
vtkDataRepresentation* AddRepresentationFromInputConnection(vtkAlgorithmOutput* conn);
// Description:
// Convenience method which sets the representation with the
// connection and adds it to the view.
// Returns the representation internally created.
// NOTE: The returned representation pointer is not reference-counted,
// so you MUST call Register() on the representation if you want to
// keep a reference to it.
vtkDataRepresentation* SetRepresentationFromInputConnection(vtkAlgorithmOutput* conn);
// Description:
// Convenience method which creates a simple representation with the
// specified input and adds it to the view.
// NOTE: The returned representation pointer is not reference-counted,
// so you MUST call Register() on the representation if you want to
// keep a reference to it.
vtkDataRepresentation* AddRepresentationFromInput(vtkDataObject* input);
// Description:
// Convenience method which sets the representation to the
// specified input and adds it to the view.
// NOTE: The returned representation pointer is not reference-counted,
// so you MUST call Register() on the representation if you want to
// keep a reference to it.
vtkDataRepresentation* SetRepresentationFromInput(vtkDataObject* input);
// Description:
// Removes the representation from the view.
void RemoveRepresentation(vtkDataRepresentation* rep);
// Description:
// Removes any representation with this connection from the view.
void RemoveRepresentation(vtkAlgorithmOutput* rep);
// Description:
// Removes all representations from the view.
void RemoveAllRepresentations();
// Description:
// Returns the number of representations from first port(0) in this view.
int GetNumberOfRepresentations();
// Description:
// The representation at a specified index.
vtkDataRepresentation* GetRepresentation(int index = 0);
// Description:
// Check to see if a representation is present in the view.
bool IsRepresentationPresent(vtkDataRepresentation* rep);
// Description:
// Update the view.
virtual void Update();
// Description:
// Apply a theme to the view.
virtual void ApplyViewTheme(vtkViewTheme* vtkNotUsed(theme)) { }
//BTX
// Description:
// Returns the observer that the subclasses can use to listen to additional
// events. Additionally these subclasses should override
// ProcessEvents() to handle these events.
vtkCommand* GetObserver();
// Description:
// A ptr to an instance of ViewProgressEventCallData is provided in the call
// data when vtkCommand::ViewProgressEvent is fired.
class ViewProgressEventCallData
{
const char* Message;
double Progress;
public:
ViewProgressEventCallData(const char* msg, double progress)
{
this->Message = msg;
this->Progress = progress;
}
~ViewProgressEventCallData()
{
this->Message = 0;
}
// Description:
// Get the message.
const char* GetProgressMessage() const
{ return this->Message; }
// Description:
// Get the progress value in range [0.0, 1.0].
double GetProgress() const
{ return this->Progress; }
};
//ETX
// Description:
// Meant for use by subclasses and vtkRepresentation subclasses.
// Call this method to register vtkObjects (generally
// vtkAlgorithm subclasses) which fire vtkCommand::ProgressEvent with the
// view. The view listens to vtkCommand::ProgressEvent and fires
// ViewProgressEvent with ViewProgressEventCallData containing the message and
// the progress amount. If message is not provided, then the class name for
// the algorithm is used.
void RegisterProgress(vtkObject* algorithm, const char* message=NULL);
// Description:
// Unregister objects previously registered with RegisterProgress.
void UnRegisterProgress(vtkObject* algorithm);
//BTX
protected:
vtkView();
~vtkView();
// Description:
// Called to process events.
// The superclass processes selection changed events from its representations.
// This may be overridden by subclasses to process additional events.
virtual void ProcessEvents(vtkObject* caller, unsigned long eventId,
void* callData);
// Description:
// Create a default vtkDataRepresentation for the given vtkAlgorithmOutput.
// View subclasses may override this method to create custom representations.
// This method is called by Add/SetRepresentationFromInputConnection.
// NOTE, the caller must delete the returned vtkDataRepresentation.
virtual vtkDataRepresentation* CreateDefaultRepresentation(vtkAlgorithmOutput* conn);
// Description:
// Subclass "hooks" for notifying subclasses of vtkView when representations are added
// or removed. Override these methods to perform custom actions.
virtual void AddRepresentationInternal(vtkDataRepresentation* vtkNotUsed(rep)) {}
virtual void RemoveRepresentationInternal(vtkDataRepresentation* vtkNotUsed(rep)) {}
// Description:
// True if the view takes a single representation that should be reused on
// Add/SetRepresentationFromInput(Connection) calls. Default is off.
vtkSetMacro(ReuseSingleRepresentation, bool);
vtkGetMacro(ReuseSingleRepresentation, bool);
vtkBooleanMacro(ReuseSingleRepresentation, bool);
bool ReuseSingleRepresentation;
private:
vtkView(const vtkView&); // Not implemented.
void operator=(const vtkView&); // Not implemented.
class vtkImplementation;
vtkImplementation* Implementation;
class Command;
friend class Command;
Command* Observer;
class vtkInternal;
vtkInternal* Internal;
//ETX
};
#endif
|