Coin Logo http://www.sim.no
http://www.coin3d.org

SoScale2Dragger.h
1 #ifndef COIN_SOSCALE2DRAGGER_H
2 #define COIN_SOSCALE2DRAGGER_H
3 
4 /**************************************************************************\
5  *
6  * This file is part of the Coin 3D visualization library.
7  * Copyright (C) 1998-2007 by Systems in Motion. All rights reserved.
8  *
9  * This library is free software; you can redistribute it and/or
10  * modify it under the terms of the GNU General Public License
11  * ("GPL") version 2 as published by the Free Software Foundation.
12  * See the file LICENSE.GPL at the root directory of this source
13  * distribution for additional information about the GNU GPL.
14  *
15  * For using Coin with software that can not be combined with the GNU
16  * GPL, and for taking advantage of the additional benefits of our
17  * support services, please contact Systems in Motion about acquiring
18  * a Coin Professional Edition License.
19  *
20  * See http://www.coin3d.org/ for more information.
21  *
22  * Systems in Motion, Postboks 1283, Pirsenteret, 7462 Trondheim, NORWAY.
23  * http://www.sim.no/ sales@sim.no coin-support@coin3d.org
24  *
25 \**************************************************************************/
26 
27 #include <Inventor/draggers/SoDragger.h>
28 #include <Inventor/fields/SoSFVec3f.h>
29 
30 class SoSensor;
31 class SoFieldSensor;
32 class SbPlaneProjector;
33 
34 
35 class COIN_DLL_API SoScale2Dragger : public SoDragger {
36  typedef SoDragger inherited;
37 
38  SO_KIT_HEADER(SoScale2Dragger);
39 
40  SO_KIT_CATALOG_ENTRY_HEADER(feedback);
41  SO_KIT_CATALOG_ENTRY_HEADER(feedbackActive);
42  SO_KIT_CATALOG_ENTRY_HEADER(feedbackSwitch);
43  SO_KIT_CATALOG_ENTRY_HEADER(scaler);
44  SO_KIT_CATALOG_ENTRY_HEADER(scalerActive);
45  SO_KIT_CATALOG_ENTRY_HEADER(scalerSwitch);
46 
47 
48 public:
49  static void initClass(void);
50  SoScale2Dragger(void);
51 
53 
54 protected:
55  ~SoScale2Dragger();
56  virtual SbBool setUpConnections(SbBool onoff, SbBool doitalways = FALSE);
57 
58  static void startCB(void * f, SoDragger * d);
59  static void motionCB(void * f, SoDragger * d);
60  static void finishCB(void * f, SoDragger * d);
61  static void fieldSensorCB(void * f, SoSensor * s);
62  static void valueChangedCB(void * f, SoDragger * d);
63 
64  void dragStart(void);
65  void drag(void);
66  void dragFinish(void);
67 
70 };
71 
72 #endif // !COIN_SOSCALE2DRAGGER_H
SoScale2Dragger::SoScale2Dragger
SoScale2Dragger(void)
Definition: SoScale2Dragger.cpp:131
SoSFVec3f
The SoSFVec3f class is a container for an SbVec3f vector.
Definition: SoSFVec3f.h:31
SbRotation
The SbRotation class represents a rotation in 3D space.
Definition: SbRotation.h:33
SoScale2Dragger::~SoScale2Dragger
~SoScale2Dragger()
Definition: SoScale2Dragger.cpp:185
SoDragger::getLocalStartingPoint
SbVec3f getLocalStartingPoint(void)
Definition: SoDragger.cpp:805
SbMatrix
The SbMatrix class is a 4x4 dimensional representation of a matrix.
Definition: SbMatrix.h:37
SbPlaneProjector
The SbPlaneProjector class projects 2D points to 3D points in a plane.
Definition: SbPlaneProjector.h:31
SoSensor
The SoSensor class is the abstract base class for all sensors.
Definition: SoSensor.h:34
SoScale2Dragger::drag
void drag(void)
Definition: SoScale2Dragger.cpp:295
SbMatrix::setTransform
void setTransform(const SbVec3f &t, const SbRotation &r, const SbVec3f &s)
Definition: SbMatrix.cpp:812
SoFieldSensor::getAttachedField
SoField * getAttachedField(void) const
Definition: SoFieldSensor.cpp:107
SoScale2Dragger::finishCB
static void finishCB(void *f, SoDragger *d)
Definition: SoScale2Dragger.cpp:269
SoScale2Dragger::setUpConnections
virtual SbBool setUpConnections(SbBool onoff, SbBool doitalways=0)
Definition: SoScale2Dragger.cpp:193
SoSwitch
The SoSwitch class is a group node which selects one child subgraph for traversal.
Definition: SoSwitch.h:37
SoInteractionKit::setSwitchValue
static void setSwitchValue(SoNode *node, const int newVal)
Definition: SoInteractionKit.cpp:358
SoDelayQueueSensor::setPriority
void setPriority(uint32_t pri)
Definition: SoDelayQueueSensor.cpp:108
SoDragger
The SoDragger class is the base class for all draggers.
Definition: SoDragger.h:53
SoInteractionKit::readDefaultParts
static void readDefaultParts(const char *fileName, const char defaultBuffer[], int defBufSize)
Definition: SoInteractionKit.cpp:433
SoDragger::addFinishCallback
void addFinishCallback(SoDraggerCB *func, void *data=NULL)
Definition: SoDragger.cpp:611
SoFieldSensor::detach
void detach(void)
Definition: SoFieldSensor.cpp:92
SoInteractionKit::setUpConnections
virtual SbBool setUpConnections(SbBool onoff, SbBool doitalways=0)
Definition: SoInteractionKit.cpp:648
SoScale2Dragger::startCB
static void startCB(void *f, SoDragger *d)
Definition: SoScale2Dragger.cpp:253
SoDragger::getViewVolume
const SbViewVolume & getViewVolume(void)
Definition: SoDragger.cpp:1032
SbProjector::setWorkingSpace
virtual void setWorkingSpace(const SbMatrix &space)
Definition: SbProjector.cpp:133
SoDragger::addValueChangedCallback
void addValueChangedCallback(SoDraggerCB *func, void *data=NULL)
Definition: SoDragger.cpp:634
SoDragger::setMotionMatrix
void setMotionMatrix(const SbMatrix &newmatrix)
Definition: SoDragger.cpp:905
SoScale2Dragger::valueChangedCB
static void valueChangedCB(void *f, SoDragger *d)
Definition: SoScale2Dragger.cpp:237
SbMatrix::getTransform
void getTransform(SbVec3f &t, SbRotation &r, SbVec3f &s, SbRotation &so) const
Definition: SbMatrix.cpp:997
SbProjector::setViewVolume
virtual void setViewVolume(const SbViewVolume &vol)
Definition: SbProjector.cpp:112
SoScale2Dragger::fieldSensor
SoFieldSensor * fieldSensor
Definition: SoScale2Dragger.h:68
SoDragger::appendScale
static SbMatrix appendScale(const SbMatrix &mtx, const SbVec3f &scale, const SbVec3f &scalecenter, const SbMatrix *conversion=NULL)
Definition: SoDragger.cpp:1271
SbVec3f
The SbVec3f class is a 3 dimensional vector with floating point coordinates.
Definition: SbVec3f.h:37
SoBaseKit::connectionsSetUp
SbBool connectionsSetUp
Definition: SoBaseKit.h:142
SoFieldSensor::attach
void attach(SoField *field)
Definition: SoFieldSensor.cpp:77
SoDragger::getMotionMatrix
const SbMatrix & getMotionMatrix(void)
Definition: SoDragger.cpp:688
SoFieldSensor
The SoFieldSensor class detects changes to a field.
Definition: SoFieldSensor.h:29
SoInteractionKit
The SoInteractionKit class is a base class for draggers.
Definition: SoInteractionKit.h:41
SoSeparator
The SoSeparator class is a state-preserving group node.
Definition: SoSeparator.h:34
SoDragger::getNormalizedLocaterPosition
SbVec2f getNormalizedLocaterPosition(void)
Definition: SoDragger.cpp:1408
SoScale2Dragger::scaleFactor
SoSFVec3f scaleFactor
Definition: SoScale2Dragger.h:52
SoScale2Dragger::fieldSensorCB
static void fieldSensorCB(void *f, SoSensor *s)
Definition: SoScale2Dragger.cpp:220
SoDragger::getStartMotionMatrix
const SbMatrix & getStartMotionMatrix(void)
Definition: SoDragger.cpp:930
SoScale2Dragger
The SoScale2Dragger class provides a mechanism for the end-user to scale in two dimensions.
Definition: SoScale2Dragger.h:35
SoScale2Dragger::dragFinish
void dragFinish(void)
Definition: SoScale2Dragger.cpp:326
SoDragger::addStartCallback
void addStartCallback(SoDraggerCB *func, void *data=NULL)
Definition: SoDragger.cpp:570
SoScale2Dragger::motionCB
static void motionCB(void *f, SoDragger *d)
Definition: SoScale2Dragger.cpp:261
SoInteractionKit::fieldSensorCB
static void fieldSensorCB(void *, SoSensor *)
Definition: SoInteractionKit.cpp:725
SoScale2Dragger::dragStart
void dragStart(void)
Definition: SoScale2Dragger.cpp:279
SoDragger::addMotionCallback
void addMotionCallback(SoDraggerCB *func, void *data=NULL)
Definition: SoDragger.cpp:591
SbPlaneProjector::setPlane
void setPlane(const SbPlane &plane)
Definition: SbPlaneProjector.cpp:183
SbPlane
The SbPlane class represents a plane in 3D space.
Definition: SbPlane.h:34
SoDragger::initClass
static void initClass(void)
Definition: SoDragger.cpp:388
SoInteractionKit::setPartAsDefault
virtual SbBool setPartAsDefault(const SbName &partname, SoNode *node, SbBool onlyifdefault=1)
Definition: SoInteractionKit.cpp:271
SbPlaneProjector::project
virtual SbVec3f project(const SbVec2f &point)
Definition: SbPlaneProjector.cpp:101
SoScale2Dragger::planeProj
SbPlaneProjector * planeProj
Definition: SoScale2Dragger.h:69
SoDragger::getLocalToWorldMatrix
SbMatrix getLocalToWorldMatrix(void)
Definition: SoDragger.cpp:776

Copyright © 1998-2007 by Systems in Motion AS. All rights reserved.

Generated on Wed Jul 24 2019 for Coin by Doxygen. 1.8.17