/usr/include/paraview/pqView.h is in paraview-dev 4.0.1-1ubuntu1.
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 | /*=========================================================================
Program: ParaView
Module: pqView.h
Copyright (c) 2005-2008 Sandia Corporation, Kitware Inc.
All rights reserved.
ParaView is a free software; you can redistribute it and/or modify it
under the terms of the ParaView license version 1.2.
See License_v1.2.txt for the full ParaView license.
A copy of this license can be obtained by contacting
Kitware Inc.
28 Corporate Drive
Clifton Park, NY 12065
USA
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHORS OR
CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
=========================================================================*/
#ifndef __pqView_h
#define __pqView_h
#include "pqProxy.h"
#include <QSize> // needed for QSize.
class pqOutputPort;
class pqPipelineSource;
class pqRepresentation;
class pqServer;
class pqUndoStack;
class pqViewInternal;
class QWidget;
class vtkImageData;
class vtkSMSourceProxy;
class vtkSMViewProxy;
class vtkView;
/// This is a PQ abstraction of a generic view module. Subclasses can be
/// specific for different types of view such as render view, histogram view
/// etc.
class PQCORE_EXPORT pqView : public pqProxy
{
Q_OBJECT
typedef pqProxy Superclass;
public:
virtual ~pqView();
/// Returns the internal render Module proxy associated with this object.
vtkSMViewProxy* getViewProxy() const;
/// Return the client-side vtkView encapsulated by this view (if any),
/// or return NULL.
virtual vtkView* getClientSideView() const;
/// Return a widget associated with this view
virtual QWidget* getWidget() = 0;
/// Returns if this view module can support
/// undo/redo. Returns false by default. Subclassess must override
/// if that's not the case.
/// View modules that support undo must fire
/// all undo related signals defined by this class.
virtual bool supportsUndo() const { return false; }
/// Returns the type of this view module.
QString getViewType() const
{ return this->ViewType; }
/// Computes the magnification and view size given the current view size for
/// the full size for the view.
static int computeMagnification(const QSize& fullsize, QSize& viewsize);
public slots:
/// Request a StillRender on idle. Multiple calls are collapsed into one.
virtual void render();
/// Forces an immediate render.
virtual void forceRender();
/// Cancels any pending renders.
void cancelPendingRenders();
/// Called to undo interaction.
/// View modules supporting interaction undo must override this method.
virtual void undo() {}
/// Called to redo interaction.
/// View modules supporting interaction undo must override this method.
virtual void redo() {}
/// Called to reset the view's display.
/// For example, reset the camera or zoom level.
/// The default implementation does nothing, but subclasses may override.
virtual void resetDisplay() {}
public:
/// Returns true if undo can be done.
virtual bool canUndo() const {return false;}
/// Returns true if redo can be done.
virtual bool canRedo() const {return false;}
/// Save a screenshot for the render module. If width or height ==0,
/// the current window size is used.
/// TODO: pqView should probably report file types it supports
virtual bool saveImage(int width, int height, const QString& filename) =0;
/// Returns the current size of the rendering context.
/// Default implementation returns the client size ofthe widget. Subclasses
/// may override to change this behavior.
virtual QSize getSize();
/// Capture the view image into a new vtkImageData with the given magnification
/// and returns it.
virtual vtkImageData* captureImage(int magnification) =0;
virtual vtkImageData* captureImage(const QSize& size);
/// This method checks if the representation is shown in this view.
bool hasRepresentation(pqRepresentation* repr) const;
/// Returns the number representations in the view.
int getNumberOfRepresentations() const;
// Returns the number of representations currently visible in the view.
int getNumberOfVisibleRepresentations() const;
/// Returns the representation for the specified index where
/// (index < getNumberOfRepresentations()).
pqRepresentation* getRepresentation(int index) const;
/// Returns a list of representations in this view.
QList<pqRepresentation*> getRepresentations() const;
/// This method returns is any pqPipelineSource can be dislayed in this
/// view. This is a convenience method, it gets
/// the pqDisplayPolicy object from the pqApplicationCore
/// are queries it.
virtual bool canDisplay(pqOutputPort* opPort) const;
/// The annotation link used on representations to share the selection
/// and annotations. This is only used in views aware of this link.
virtual void setAnnotationLink(vtkSMSourceProxy* link);
vtkSMSourceProxy* getAnnotationLink();
signals:
/// Fired when the vtkSMViewProxy fire the vtkCommand::UpdateDataEvent
void updateDataEvent();
/// Fired after a representation has been added to this view.
void representationAdded(pqRepresentation*);
/// Fired after a representation has been removed from this view.
void representationRemoved(pqRepresentation*);
/// Fired when the render module fires a vtkCommand::StartEvent
/// signalling the beginning of rendering. Subclasses must fire
/// these signals at appropriate times.
void beginRender();
/// Fired when the render module fires a vtkCommand::EndEvent
/// signalling the end of rendering.
/// Subclasses must fire these signals at appropriate times.
void endRender();
/// Fired when any representation visibility changes.
void representationVisibilityChanged(pqRepresentation* repr, bool visible);
/// Fired when interaction undo stack status changes.
void canUndoChanged(bool);
/// Fired when interaction undo stack status changes.
void canRedoChanged(bool);
/// Fired when a selection is made in this view.
/// \c opport is the output port for the source that got selected.
/// the selection input on the source proxy for the opport must already
/// have been initialized to a selection source.
void selected(pqOutputPort* opport);
/// Fired when a port is picked.
/// \c opport is the port that got picked.
void picked(pqOutputPort* opport);
/// Fired before doing any actions that may result in progress events that
/// must be reported by the client.
void beginProgress();
/// Fired after performing any actions that may result in progress events.
/// Must match beginProgress() calls.
void endProgress();
/// Fired to notify the current execution progress. This will be generally
/// have any effect only if beginProgress() has been fired before firing this
/// signal.
void progress(const QString& message, int percent_progress);
/// Fired when UseMultipleRepresentationSelection is set to on and
/// selection on multiple representations is made in this view.
/// \c opports is a list of opport, and opport is the output port for
/// the source that got selected. the selection input on the source
/// proxy for the opport must already have been
/// initialized to a selection source.
void multipleSelected(QList<pqOutputPort*> opports);
private slots:
/// Called when the "Representations" property changes.
void onRepresentationsChanged();
/// Called when the representation fires visibilityChanged() signal.
void onRepresentationVisibilityChanged(bool);
/// Called when a new representation is registered by the ServerManagerModel.
/// We check if the representation belongs to this view.
void representationCreated(pqRepresentation* repr);
/// This is called when the timer in render() times out. We test if the
/// current moment is a reasonable moment to render and if so, call
/// forceRender(). If there are any pending progress events, then we treat the
/// moment as not a "reasonable moment" to render and defer the render again.
void tryRender();
protected:
/// Constructor:
/// \c type :- view type.
/// \c group :- SManager registration group.
/// \c name :- SManager registration name.
/// \c view :- View proxy.
/// \c server:- server on which the proxy is created.
/// \c parent:- QObject parent.
pqView( const QString& type,
const QString& group,
const QString& name,
vtkSMViewProxy* view,
pqServer* server,
QObject* parent=NULL);
/// Use this method to initialize the pqObject state using the
/// underlying vtkSMProxy. This needs to be done only once,
/// after the object has been created.
/// Overridden to update the list of representations currently available.
virtual void initialize();
private:
pqView(const pqView&); // Not implemented.
void operator=(const pqView&); // Not implemented.
pqViewInternal* Internal;
QString ViewType;
};
#endif
|