/usr/include/paraview/pq3DWidget.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 | /*=========================================================================
Program: ParaView
Module: pq3DWidget.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 pq3DWidget_h
#define pq3DWidget_h
#include "pqComponentsModule.h"
#include "pqProxyPanel.h"
class pq3DWidgetInternal;
class pqPipelineSource;
class pqProxy;
class pqRenderViewBase;
class QKeySequence;
class vtkObject;
class vtkPVXMLElement;
class vtkSMNewWidgetRepresentationProxy;
class vtkSMProperty;
/// pq3DWidget is the abstract superclass for all 3D widgets.
/// This class represents a 3D Widget proxy as well as the GUI for the
/// widget.
class PQCOMPONENTS_EXPORT pq3DWidget : public pqProxyPanel
{
Q_OBJECT
typedef pqProxyPanel Superclass;
public:
pq3DWidget(vtkSMProxy* referenceProxy, vtkSMProxy* proxy, QWidget* parent=0);
virtual ~pq3DWidget();
// This method creates widgets using the hints provided by
// the proxy. If a proxy needs more that one
// 3D widget, this method will create all the 3D widgets and
// return them. There is no parent associated with the newly
// created 3D widgets, it's the responsibility of the caller
// to do the memory management for the 3D widgets.
static QList<pq3DWidget*> createWidgets(vtkSMProxy* refProxy, vtkSMProxy* proxy);
/// Controlled proxy is a proxy which is controlled by the 3D widget.
/// A controlled proxy must provide "Hints" describing how
/// the properties of the controlled proxy are controlled by the
/// 3D widget.
vtkSMProxy* getControlledProxy() const;
vtkSMProxy* getReferenceProxy() const;
/// Set the hints XML to be using to map the 3D widget to the controlled
/// proxy. This method must be called only after the controlled
/// proxy has been set. The argument is the element
/// <PropertyGroup /> which will be controlled by this widget.
void setHints(vtkPVXMLElement* element);
vtkPVXMLElement* getHints() const;
/// Return the 3D Widget proxy.
vtkSMNewWidgetRepresentationProxy* getWidgetProxy() const;
/// Returns true if 3D widget visibility is enabled.
/// Note: this *does not* indicate that the 3D widget is currently visible
/// in the display, since this widget's panel might not be visible.
bool widgetVisible() const;
/// Returns true if 3D widget is selected.
bool widgetSelected() const;
/// Returns the current render view.
pqRenderViewBase* renderView() const;
/// Reset the bounds to the specified bounds.
/// This typically calls PlaceWidget on the underlying 3D Widget
/// with reference proxy bounds.
virtual void resetBounds(double bounds[6])=0;
signals:
/// Notifies observers that widget visibility has changed
void widgetVisibilityChanged(bool);
/// Notifies observers that the user is dragging the 3D widget
void widgetStartInteraction();
/// Notifies observers that the user is done dragging the 3D widget
void widgetEndInteraction();
/// Notifies observers that the user is dragging the 3D widget
void widgetInteraction();
public slots:
/// Sets 3D widget visibility
void setWidgetVisible(bool);
/// Makes the 3D widget visible.
void showWidget();
/// Hides the 3D widget.
void hideWidget();
/// Activates the widget. Respects the visibility flag.
virtual void select();
/// Deactivates the widget.
virtual void deselect();
/// Accepts pending changes. Default implementation
/// pushes the 3D widget information property values to
/// the corresponding properties on the controlled widget.
/// The correspondence is determined from the <Hints />
/// associated with the controlled proxy.
virtual void accept();
/// Resets pending changes. Default implementation
/// pushes the property values of the controlled widget to the
/// 3D widget properties.
/// The correspondence is determined from the <Hints />
/// associated with the controlled proxy.
virtual void reset();
/// Set the view that this panel works with
virtual void setView(pqView*);
/// Resets the bounds of the 3D widget to the reference proxy bounds.
/// This typically calls PlaceWidget on the underlying 3D Widget
/// with reference proxy bounds.
/// This should be explicitly called after the panel is created
/// and the widget is initialized i.e. the reference proxy, controlled proxy
/// and hints have been set.
/// Default implementation uses the getReferenceInputBounds() to get the
/// bounds and then calls resetBounds(double bounds[]). Subclasses generally
/// need to override this resetBounds(double*) method.
virtual void resetBounds();
/// When set to true, instead of using the referenceProxy to obtain the
/// default bounds to reset to, it will use the bounds for the selected sources
/// as indicated by
/// pqApplicationCore::getSelectionModel()->getSelectionDataBounds().
/// Default is false.
virtual void setUseSelectionDataBounds(bool use)
{ this->UseSelectionDataBounds = use; }
bool useSelectionDataBounds()
{return this->UseSelectionDataBounds; }
protected slots:
/// Called to request a render.
void render();
// When set to true, instead of intersecting with the mesh surface for picking, it will only get a close point from the mesh
void setPickOnMeshPoint(bool);
/// triggers a pick action using the current location of the mouse.
void pickPoint();
/// Called on each pick, default implementation does nothing.
virtual void pick(double, double, double) {};
/// Called when master/slave change
virtual void updateMasterEnableState(bool);
/// Handle custom user notification to show/hide corresponding widget
void handleReferenceProxyUserEvent(vtkObject*, unsigned long, void*);
protected:
// Return true if picking is on mesh point only
bool pickOnMeshPoint() const;
/// Subclasses can override this method to map properties to
/// GUI. Default implementation updates the internal datastructures
/// so that default implementations can be provided for
/// accept/reset.
virtual void setControlledProperty(const char* function,
vtkSMProperty * controlled_property);
/// Subclasses should call this method if they support picking.
/// When the user picks a position,
/// the virtual method pick(double, double, double) will be called.
void pickingSupported(const QKeySequence& key);
void setControlledProperty(vtkSMProperty* widget_property, vtkSMProperty* controlled_property);
// Subclasses must set the widget proxy.
void setWidgetProxy(vtkSMNewWidgetRepresentationProxy*);
/// Called when one of the controlled properties change (e.g: by undo/redo)
virtual void onControlledPropertyChanged();
/// Used to get the input bounds on for the reference proxy, if any.
/// returns 1 on success, 0 otherwise.
int getReferenceInputBounds(double bounds[6]) const;
/// Update the widget visibility according to the WidgetVisible and Selected flags
virtual void updateWidgetVisibility();
/// Update the widget visibility and enable state
virtual void updateWidgetState(bool visible, bool enable);
/// updates the enable state of the picking shortcut.
virtual void updatePickShortcut();
virtual void updatePickShortcut(bool pickable);
private:
void setControlledProxy(vtkSMProxy*);
pq3DWidgetInternal* const Internal;
bool UseSelectionDataBounds;
class pqStandardWidgets;
};
#endif
|