/usr/include/paraview/pqRubberBandHelper.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 | /*=========================================================================
Program: ParaView
Module: pqRubberBandHelper.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 __pqRubberBandHelper_h
#define __pqRubberBandHelper_h
#include "pqCoreModule.h"
#include <QObject>
class pqRenderView;
class pqView;
class vtkObject;
/*! \brief Utility to switch interactor styles in 3D views.
*
* pqRubberBandHelper standardizes the mechanism by which 3D views
* are switched between interaction and rubber band modes.
* TODO: We may want to extend this class to create different type of selections
* i.e. surface/frustrum.
*
* @deprecated Use pqRenderViewSelectionReaction instead.
*/
class PQCORE_EXPORT pqRubberBandHelper : public QObject
{
Q_OBJECT
typedef QObject Superclass;
public:
// @deprecated Please modify your code to use pqRenderViewSelectionReaction
// instead.
pqRubberBandHelper(QObject* parent=NULL);
virtual ~pqRubberBandHelper();
/// Returns the currently selected render view.
pqRenderView* getRenderView() const;
//BTX
enum Modes
{
INTERACT,
SELECT, //aka, Surface selection
SELECT_POINTS,
FRUSTUM,
FRUSTUM_POINTS,
BLOCKS,
ZOOM,
PICK,
PICK_ON_CLICK,
FAST_INTERSECT,
POLYGON_POINTS,
POLYGON_CELLS
};
// PICK_ON_CLICK mode is same as pick, except that the helper does not change
// the interactor or draw any rubber bands, now change the cursor. It just
// sets up observer to call "pick" when user clicks.
//ETX
public slots:
/// Set active view. If a view has been set previously, this method ensures
/// that it is not in selection mode.
void setView(pqView*);
/// Begin rubber band surface selection on the view.
/// Has any effect only if active view is a render view.
void beginSurfaceSelection();
void beginSurfacePointsSelection();
void beginFrustumSelection();
void beginFrustumPointsSelection();
void beginBlockSelection();
void beginZoom();
void beginPick();
void beginPickOnClick();
void beginFastIntersect();
/// Instantly trigger a FastIntersect processing which will fire
/// intersectionFinished(xyz) based on the curent mouse location.
void triggerFastIntersect();
/// End rubber band selection.
/// Has any effect only if active view is a render view.
void endSelection();
void endPick()
{ this->endSelection(); }
void endZoom()
{ this->endSelection(); }
/// Called to disable selection.
void DisabledPush();
/// Called to pop disabling of selection. If there are as many DisabledPop() as
/// DisabledPush(), the selection will be enabled.
void DisabledPop();
signals:
/// fired after mouse up in selection mode
void selectionFinished(int xmin, int ymin, int xmax, int ymax);
/// Fired to indicate whether the selection can be created on the currently set
/// view.
void enableSurfaceSelection(bool enabled);
void enableSurfacePointsSelection(bool enabled);
void enableFrustumSelection(bool enabled);
void enableFrustumPointSelection(bool enabled);
void enableBlockSelection(bool enabled);
void enableZoom(bool enabled);
void enablePick(bool enabled);
void enablePolygonPointsSelection(bool enabled);
void enablePolygonCellsSelection(bool enabled);
/// Fired with selection mode changes.
/// \c selectionMode is enum Modes{...}.
void selectionModeChanged(int selectionMode);
/// This is inverse of selectionModeChanged signal, provided for convenience.
void interactionModeChanged(bool notselectable);
/// Fired to mark the start and ends of selection.
void startSelection();
void stopSelection();
void selecting(bool);
/// Fired in FAST_INTERSECT_MODE
void intersectionFinished(double x, double y, double z);
protected slots:
void emitEnabledSignals();
void delayedSelectionChanged()
{
this->onSelectionChanged(NULL, 0, NULL);
}
protected:
int setRubberBandOn(int mode);
int setRubberBandOff();
int Mode;
int Xs, Ys, Xe, Ye;
int DisableCount;
// Called whenever a zoom is made in the view
void onZoom(vtkObject*, unsigned long, void*);
// Called whenever a pick_on_click is made in the view
void onPickOnClick(vtkObject*, unsigned long, void*);
// Called whenever a selection is made in the view.
void onSelectionChanged(vtkObject*, unsigned long, void*);
// Called whenever a polygon is drawn in the view
void onPolygonSelection(vtkObject*, unsigned long, void*);
private:
class pqInternal;
pqInternal* Internal;
};
#endif
|