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

SoCenterballDragger.h
1#ifndef COIN_SOCENTERBALLDRAGGER_H
2#define COIN_SOCENTERBALLDRAGGER_H
3
4/**************************************************************************\
5 *
6 * This file is part of the Coin 3D visualization library.
7 * Copyright (C) by Kongsberg Oil & Gas Technologies.
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 Kongsberg Oil & Gas Technologies
18 * about acquiring a Coin Professional Edition License.
19 *
20 * See http://www.coin3d.org/ for more information.
21 *
22 * Kongsberg Oil & Gas Technologies, Bygdoy Alle 5, 0257 Oslo, NORWAY.
23 * http://www.sim.no/ sales@sim.no coin-support@coin3d.org
24 *
25\**************************************************************************/
26
28#include <Inventor/tools/SbLazyPimplPtr.h>
29#include <Inventor/fields/SoSFRotation.h>
30#include <Inventor/fields/SoSFVec3f.h>
31
32class SoSensor;
33class SoFieldSensor;
34class SoCenterballDraggerP;
35
36class COIN_DLL_API SoCenterballDragger : public SoDragger {
37 typedef SoDragger inherited;
38
39 SO_KIT_HEADER(SoCenterballDragger);
40
41 SO_KIT_CATALOG_ENTRY_HEADER(XAxis);
42 SO_KIT_CATALOG_ENTRY_HEADER(XAxisSwitch);
43 SO_KIT_CATALOG_ENTRY_HEADER(XCenterChanger);
44 SO_KIT_CATALOG_ENTRY_HEADER(XRotator);
45 SO_KIT_CATALOG_ENTRY_HEADER(YAxis);
46 SO_KIT_CATALOG_ENTRY_HEADER(YAxisSwitch);
47 SO_KIT_CATALOG_ENTRY_HEADER(YCenterChanger);
48 SO_KIT_CATALOG_ENTRY_HEADER(YRotator);
49 SO_KIT_CATALOG_ENTRY_HEADER(ZAxis);
50 SO_KIT_CATALOG_ENTRY_HEADER(ZAxisSwitch);
51 SO_KIT_CATALOG_ENTRY_HEADER(ZCenterChanger);
52 SO_KIT_CATALOG_ENTRY_HEADER(ZRotator);
53 SO_KIT_CATALOG_ENTRY_HEADER(antiSquish);
54 SO_KIT_CATALOG_ENTRY_HEADER(lightModel);
55 SO_KIT_CATALOG_ENTRY_HEADER(rot2X90);
56 SO_KIT_CATALOG_ENTRY_HEADER(rotX90);
57 SO_KIT_CATALOG_ENTRY_HEADER(rotY90);
58 SO_KIT_CATALOG_ENTRY_HEADER(rotator);
59 SO_KIT_CATALOG_ENTRY_HEADER(surroundScale);
60 SO_KIT_CATALOG_ENTRY_HEADER(translateToCenter);
61
62public:
63 static void initClass(void);
65
66 virtual void saveStartParameters(void);
67
70
71protected:
72 virtual ~SoCenterballDragger(void);
73 void transferCenterDraggerMotion(SoDragger * childdragger);
74 void setSwitches(SoDragger * activechild);
75 virtual SbBool setUpConnections(SbBool onoff, SbBool doitalways = FALSE);
76 virtual void setDefaultOnNonWritingFields(void);
77
78 static void fieldSensorCB(void * f, SoSensor * s);
79 static void valueChangedCB(void * f, SoDragger * d);
80 static void kidStartCB(void * f, SoDragger * d);
81 static void kidFinishCB(void * f, SoDragger * d);
82
83 virtual void getBoundingBox(SoGetBoundingBoxAction * action);
84 virtual void getMatrix(SoGetMatrixAction * action);
85
88
89private:
90 SbVec3f savedtransl;
91 SbVec3f savedcenter;
92 void addChildDragger(SoDragger *child);
93 void removeChildDragger(const char *childname);
94
95private:
96 SbLazyPimplPtr<SoCenterballDraggerP> pimpl;
97
98 // NOT IMPLEMENTED:
100 SoCenterballDragger & operator & (const SoCenterballDragger & rhs);
101}; // SoCenterballDragger
102
103#endif // !COIN_SOCENTERBALLDRAGGER_H
The SbVec3f class is a 3 dimensional vector with floating point coordinates.
Definition SbVec3f.h:40
The SoCenterballDragger class is a dragger you can rotate and translate.
Definition SoCenterballDragger.h:36
SoFieldSensor * rotFieldSensor
Definition SoCenterballDragger.h:86
SoSFRotation rotation
Definition SoCenterballDragger.h:68
SoFieldSensor * centerFieldSensor
Definition SoCenterballDragger.h:87
SoSFVec3f center
Definition SoCenterballDragger.h:69
The SoDragger class is the base class for all draggers.
Definition SoDragger.h:55
static void initClass(void)
Definition SoDragger.cpp:399
virtual void setDefaultOnNonWritingFields(void)
Definition SoDragger.cpp:1791
virtual void getMatrix(SoGetMatrixAction *action)
Definition SoDragger.cpp:528
virtual void getBoundingBox(SoGetBoundingBoxAction *action)
Definition SoDragger.cpp:1763
virtual void saveStartParameters(void)
Definition SoDragger.cpp:985
The SoFieldSensor class detects changes to a field.
Definition SoFieldSensor.h:29
The SoGetBoundingBoxAction class calculates bounding boxes for nodes and subgraphs.
Definition SoGetBoundingBoxAction.h:36
The SoGetMatrixAction class is an action for accumulating the transformation matrix of a subgraph.
Definition SoGetMatrixAction.h:37
static void fieldSensorCB(void *, SoSensor *)
Definition SoInteractionKit.cpp:742
virtual SbBool setUpConnections(SbBool onoff, SbBool doitalways=FALSE)
Definition SoInteractionKit.cpp:665
The SoSFRotation class is a container for an SbRotation.
Definition SoSFRotation.h:31
The SoSFVec3f class is a container for an SbVec3f vector.
Definition SoSFVec3f.h:31
The SoSensor class is the abstract base class for all sensors.
Definition SoSensor.h:34

Copyright © 1998-2010 by Kongsberg Oil & Gas Technologies. All rights reserved.

Generated on Wed Jul 17 2024 for Coin by Doxygen 1.12.0.