Gui: remove SoNavigationDragger (#12409)

Removed SoNavigationDragger files. These files are no longer used in the project
This commit is contained in:
mosfet80
2024-02-17 04:39:28 +01:00
committed by GitHub
parent c919ea8666
commit 749fbb33b9
6 changed files with 0 additions and 690 deletions

View File

@@ -982,7 +982,6 @@ SET(Inventor_CPP_SRCS
SoFCSelectionAction.cpp
SoFCVectorizeSVGAction.cpp
SoFCVectorizeU3DAction.cpp
SoNavigationDragger.cpp
SoAxisCrossKit.cpp
SoTextLabel.cpp
SoDatumLabel.cpp
@@ -1011,7 +1010,6 @@ SET(Inventor_SRCS
SoFCSelectionAction.h
SoFCVectorizeSVGAction.h
SoFCVectorizeU3DAction.h
SoNavigationDragger.h
SoAxisCrossKit.h
SoTextLabel.h
SoDatumLabel.h
@@ -1309,7 +1307,6 @@ if (EIGEN3_NO_DEPRECATED_COPY)
Inventor/SoAutoZoomTranslation.cpp
SoFCOffscreenRenderer.cpp
SoFCSelectionAction.cpp
SoNavigationDragger.cpp
SoFCCSysDragger.cpp
Quarter/QuarterWidget.cpp
View3DInventorViewer.cpp

View File

@@ -67,7 +67,6 @@
#include "SoFCVectorizeSVGAction.h"
#include "SoFCVectorizeU3DAction.h"
#include "SoMouseWheelEvent.h"
#include "SoNavigationDragger.h"
#include "SoTextLabel.h"
#include "SoDatumLabel.h"
#include "Inventor/MarkerBitmaps.h"
@@ -92,7 +91,6 @@ SbBool Gui::SoFCDB::isInitialized()
void Gui::SoFCDB::init()
{
SoInteraction ::init();
RotTransDragger ::initClass();
SoGLRenderActionElement ::initClass();
SoFCInteractiveElement ::initClass();
SoGLWidgetElement ::initClass();

View File

@@ -1,391 +0,0 @@
/***************************************************************************
* Copyright (c) 2005 Jürgen Riegel <juergen.riegel@web.de> *
* *
* This file is part of the FreeCAD CAx development system. *
* *
* This library is free software; you can redistribute it and/or *
* modify it under the terms of the GNU Library General Public *
* License as published by the Free Software Foundation; either *
* version 2 of the License, or (at your option) any later version. *
* *
* This library is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
* GNU Library General Public License for more details. *
* *
* You should have received a copy of the GNU Library General Public *
* License along with this library; see the file COPYING.LIB. If not, *
* write to the Free Software Foundation, Inc., 59 Temple Place, *
* Suite 330, Boston, MA 02111-1307, USA *
* *
***************************************************************************/
#include "PreCompiled.h"
#include <Inventor/nodes/SoAntiSquish.h>
#include <Inventor/nodes/SoRotation.h>
#include <Inventor/nodes/SoSeparator.h>
#include <Inventor/nodes/SoSurroundScale.h>
#include <Inventor/sensors/SoFieldSensor.h>
// Include files for child dragger classes.
#include <Inventor/draggers/SoRotateCylindricalDragger.h>
#include <Inventor/draggers/SoTranslate1Dragger.h>
// Include file for our new class.
#include "SoNavigationDragger.h"
// Include file the binaray of SoNavigationDraggerLayout.iv, the layout of the dragger.
#include "SoNavigationDraggerLayout.h"
SO_KIT_SOURCE(RotTransDragger)
// Initializes the type ID for this dragger node. This
// should be called once after SoInteraction::init().
void
RotTransDragger::initClass()
{
SO_KIT_INIT_CLASS(RotTransDragger, SoDragger, "Dragger");
}
RotTransDragger::RotTransDragger()
{
SO_KIT_CONSTRUCTOR(RotTransDragger);
// Don't create "surroundScale" by default. It's only put
// to use if this dragger is used within a manipulator.
SO_KIT_ADD_CATALOG_ENTRY(surroundScale, SoSurroundScale, true,
topSeparator, geomSeparator, true);
// Create an anti-squish node by default.
SO_KIT_ADD_CATALOG_ENTRY(antiSquish, SoAntiSquish, false,
topSeparator, geomSeparator, true);
SO_KIT_ADD_CATALOG_ENTRY(translator, SoTranslate1Dragger,
true, topSeparator, geomSeparator,
true);
SO_KIT_ADD_CATALOG_ENTRY(XRotatorSep, SoSeparator, false,
topSeparator, geomSeparator, false);
SO_KIT_ADD_CATALOG_ENTRY(XRotatorRot, SoRotation, true,
XRotatorSep,0 , false);
SO_KIT_ADD_CATALOG_ENTRY(XRotator,SoRotateCylindricalDragger,
true, XRotatorSep, 0,true);
SO_KIT_ADD_CATALOG_ENTRY(YRotator, SoRotateCylindricalDragger,
true, topSeparator, geomSeparator, true);
SO_KIT_ADD_CATALOG_ENTRY(ZRotatorSep, SoSeparator, false,
topSeparator, geomSeparator, false);
SO_KIT_ADD_CATALOG_ENTRY(ZRotatorRot, SoRotation, true,
ZRotatorSep,0 ,false);
SO_KIT_ADD_CATALOG_ENTRY(ZRotator, SoRotateCylindricalDragger,
true, ZRotatorSep, 0,true);
// Read geometry resources. Only do this the first time we
// construct one. 'geomBuffer' contains our compiled in
// defaults. The user can override these by specifying new
// scene graphs in the file:
// $(SO_DRAGGER_DIR)/rotTransDragger.iv"
if (SO_KIT_IS_FIRST_INSTANCE())
readDefaultParts("SoNavigationDraggerLayout.iv",
NavigationDraggerLayout,
strlen(NavigationDraggerLayout));
// Fields that always show current state of the dragger.
SO_KIT_ADD_FIELD(rotation, (0.0, 0.0, 0.0, 1.0));
SO_KIT_ADD_FIELD(translation, (0.0, 0.0, 0.0));
// Creates parts list and default parts for this nodekit.
SO_KIT_INIT_INSTANCE();
// Make the anti-squish node surround the biggest dimension
SoAntiSquish *myAntiSquish =
SO_GET_ANY_PART(this, "antiSquish", SoAntiSquish);
myAntiSquish->sizing = SoAntiSquish::BIGGEST_DIMENSION;
// Create the simple draggers that comprise this dragger.
// This dragger has four simple pieces:
// 1 TranslateRadialDragger
// 3 RotateCylindricalDraggers
// In the constructor, we just call SO_GET_ANY_PART to
// build each dragger.
// Within the setUpConnections() method, we will
// take care of giving these draggers new geometry and
// establishing their callbacks.
// Create the translator dragger.
SoDragger *tDragger = SO_GET_ANY_PART(this, "translator",
SoTranslate1Dragger);
(void)tDragger;
// Create the XRotator dragger.
SoDragger *XDragger = SO_GET_ANY_PART(this, "XRotator",
SoRotateCylindricalDragger);
(void)XDragger;
// Create the YRotator dragger.
SoDragger *YDragger = SO_GET_ANY_PART(this, "YRotator",
SoRotateCylindricalDragger);
(void)YDragger;
// Create the ZRotator dragger.
SoDragger *ZDragger = SO_GET_ANY_PART(this, "ZRotator",
SoRotateCylindricalDragger);
(void)ZDragger;
// Set rotations in "XRotatorRot" and "ZRotatorRot" parts.
// These parts will orient the draggers from their default
// (rotating about Y) to the desired configurations.
// By calling 'setAnyPartAsDefault' instead of 'setAnyPart'
// we ensure that they will not be written out, unless
// they are changed later on.
auto XRot = new SoRotation;
XRot->rotation.setValue(
SbRotation(SbVec3f(0,1,0), SbVec3f(1,0,0)));
setAnyPartAsDefault("XRotatorRot", XRot);
auto ZRot = new SoRotation;
ZRot->rotation.setValue(
SbRotation(SbVec3f(0,1,0), SbVec3f(0,0,1)));
setAnyPartAsDefault("ZRotatorRot", ZRot);
// Updates the fields when motionMatrix changes
addValueChangedCallback(&RotTransDragger::valueChangedCB);
// Updates motionMatrix when either field changes.
rotFieldSensor = new SoFieldSensor(
&RotTransDragger::fieldSensorCB, this);
rotFieldSensor->setPriority(0);
translFieldSensor = new SoFieldSensor(
&RotTransDragger::fieldSensorCB,this);
translFieldSensor->setPriority(0);
setUpConnections(true, true);
}
RotTransDragger::~RotTransDragger()
{
if (rotFieldSensor)
delete rotFieldSensor;
if (translFieldSensor)
delete translFieldSensor;
}
SbBool
RotTransDragger::setUpConnections(SbBool onOff, SbBool doItAlways)
{
if (!doItAlways && connectionsSetUp == onOff)
return onOff;
if (onOff) {
// We connect AFTER base class.
SoDragger::setUpConnections(onOff, doItAlways);
// For each of the simple draggers that compries this:
// [a]Call setPart after looking up our replacement parts
// in the global dictionary.
// [b]Add the invalidateSurroundScaleCB as a start and end
// callback. When using a surroundScale node, these
// trigger it to recalculate a bounding box at the
// beginning and end of dragging.
// [c]Register the dragger as a 'childDragger' of this
// one. This has the following effects:
// [1] This dragger's callbacks will be invoked
// following the child manip's callbacks.
// [2] When the child is dragged, the child's motion
// will be transferred into motion of the entire
// dragger.
SoDragger *tD =
(SoDragger *) getAnyPart("translator", false);
// [a] Set up the parts in the child dragger...
tD->setPartAsDefault("translator",
"rotTransTranslatorTranslator");
tD->setPartAsDefault("translatorActive",
"rotTransTranslatorTranslatorActive");
tD->setPartAsDefault("feedback",
"rotTransTranslatorFeedback");
tD->setPartAsDefault("feedbackActive",
"rotTransTranslatorFeedbackActive");
// [b] and [c] Add the callbacks and register the child
tD->addStartCallback(
&RotTransDragger::invalidateSurroundScaleCB, this);
tD->addFinishCallback(
&RotTransDragger::invalidateSurroundScaleCB, this);
registerChildDragger(tD);
SoDragger *XD =
(SoDragger *) getAnyPart("XRotator", false);
// [a] Set up the parts in the child dragger...
XD->setPartAsDefault("rotator",
"rotTransRotatorRotator");
XD->setPartAsDefault("rotatorActive",
"rotTransRotatorRotatorActive");
XD->setPartAsDefault("feedback",
"rotTransRotatorFeedback");
XD->setPartAsDefault("feedbackActive",
"rotTransRotatorFeedbackActive");
// [b] and [c] Add the callbacks and register the child
XD->addStartCallback(
&RotTransDragger::invalidateSurroundScaleCB, this);
XD->addFinishCallback(
&RotTransDragger::invalidateSurroundScaleCB, this);
registerChildDragger(XD);
SoDragger *YD =
(SoDragger *) getAnyPart("YRotator", false);
// [a] Set up the parts in the child dragger...
YD->setPartAsDefault("rotator",
"rotTransRotatorRotator");
YD->setPartAsDefault("rotatorActive",
"rotTransRotatorRotatorActive");
YD->setPartAsDefault("feedback",
"rotTransRotatorFeedback");
YD->setPartAsDefault("feedbackActive",
"rotTransRotatorFeedbackActive");
// [b] and [c] Add the callbacks and register the child
YD->addStartCallback(
&RotTransDragger::invalidateSurroundScaleCB, this);
YD->addFinishCallback(
&RotTransDragger::invalidateSurroundScaleCB, this);
registerChildDragger(YD);
SoDragger *ZD =
(SoDragger *) getAnyPart("ZRotator", false);
// [a] Set up the parts in the child dragger...
ZD->setPartAsDefault("rotator",
"rotTransRotatorRotator");
ZD->setPartAsDefault("rotatorActive",
"rotTransRotatorRotatorActive");
ZD->setPartAsDefault("feedback",
"rotTransRotatorFeedback");
ZD->setPartAsDefault("feedbackActive",
"rotTransRotatorFeedbackActive");
// [b] and [c] Add the callbacks and register the child
ZD->addStartCallback(
&RotTransDragger::invalidateSurroundScaleCB, this);
ZD->addFinishCallback(
&RotTransDragger::invalidateSurroundScaleCB, this);
registerChildDragger(ZD);
// Call the sensor CB to make things up-to-date.
fieldSensorCB(this, nullptr);
// Connect the field sensors
if (translFieldSensor->getAttachedField() != &translation)
translFieldSensor->attach(&translation);
if (rotFieldSensor->getAttachedField() != &rotation)
rotFieldSensor->attach(&rotation);
}
else {
// We disconnect BEFORE base class.
// Remove the callbacks from the child draggers,
// and unregister them as children.
SoDragger *tD =
(SoDragger *) getAnyPart("translator", false);
tD->removeStartCallback(
&RotTransDragger::invalidateSurroundScaleCB, this);
tD->removeFinishCallback(
&RotTransDragger::invalidateSurroundScaleCB, this);
unregisterChildDragger(tD);
SoDragger *XD =
(SoDragger *) getAnyPart("XRotator", false);
XD->removeStartCallback(
&RotTransDragger::invalidateSurroundScaleCB, this);
XD->removeFinishCallback(
&RotTransDragger::invalidateSurroundScaleCB, this);
unregisterChildDragger(XD);
SoDragger *YD =
(SoDragger *) getAnyPart("YRotator", false);
YD->removeStartCallback(
&RotTransDragger::invalidateSurroundScaleCB, this);
YD->removeFinishCallback(
&RotTransDragger::invalidateSurroundScaleCB, this);
unregisterChildDragger(YD);
SoDragger *ZD =
(SoDragger *) getAnyPart("ZRotator", false);
ZD->removeStartCallback(
&RotTransDragger::invalidateSurroundScaleCB, this);
ZD->removeFinishCallback(
&RotTransDragger::invalidateSurroundScaleCB, this);
unregisterChildDragger(ZD);
// Disconnect the field sensors.
if (translFieldSensor->getAttachedField())
translFieldSensor->detach();
if (rotFieldSensor->getAttachedField())
rotFieldSensor->detach();
SoDragger::setUpConnections(onOff, doItAlways);
}
return !(connectionsSetUp = onOff);
}
// Called when the motionMatrix changes. Sets the "translation"
// and "rotation" fields based on the new motionMatrix
void
RotTransDragger::valueChangedCB(void *, SoDragger *inDragger)
{
auto myself = static_cast<RotTransDragger *>(inDragger);
// Factor the motionMatrix into its parts
SbMatrix motMat = myself->getMotionMatrix(); // clazy:exclude=rule-of-two-soft
SbVec3f trans, scale;
SbRotation rot, scaleOrient;
motMat.getTransform(trans, rot, scale, scaleOrient);
// Set the fields. Disconnect the sensors while doing so.
myself->rotFieldSensor->detach();
myself->translFieldSensor->detach();
if (myself->rotation.getValue() != rot)
myself->rotation = rot;
if (myself->translation.getValue() != trans)
myself->translation = trans;
myself->rotFieldSensor->attach(&myself->rotation);
myself->translFieldSensor->attach(&myself->translation);
}
// If the "translation" or "rotation" field changes, changes
// the motionMatrix accordingly.
void
RotTransDragger::fieldSensorCB(void *inDragger, SoSensor *)
{
auto myself = static_cast<RotTransDragger *>(inDragger);
SbMatrix motMat = myself->getMotionMatrix(); // clazy:exclude=rule-of-two-soft
myself->workFieldsIntoTransform(motMat);
myself->setMotionMatrix(motMat);
}
// When any child dragger starts or ends a drag, tell the
// "surroundScale" part (if it exists) to invalidate its
// current bounding box value.
void
RotTransDragger::invalidateSurroundScaleCB(void *parent, SoDragger *)
{
auto myParentDragger = static_cast<RotTransDragger *>(parent);
// Invalidate the surroundScale, if it exists.
SoSurroundScale *mySS = SO_CHECK_PART(
myParentDragger, "surroundScale", SoSurroundScale);
if (mySS)
mySS->invalidate();
}
void
RotTransDragger::setDefaultOnNonWritingFields()
{
// The nodes pointed to by these part-fields may
// change after construction, but we
// don't want to write them out.
surroundScale.setDefault(true);
antiSquish.setDefault(true);
SoDragger::setDefaultOnNonWritingFields();
}

View File

@@ -1,125 +0,0 @@
/***************************************************************************
* Copyright (c) 2005 Jürgen Riegel <juergen.riegel@web.de> *
* *
* This file is part of the FreeCAD CAx development system. *
* *
* This library is free software; you can redistribute it and/or *
* modify it under the terms of the GNU Library General Public *
* License as published by the Free Software Foundation; either *
* version 2 of the License, or (at your option) any later version. *
* *
* This library is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
* GNU Library General Public License for more details. *
* *
* You should have received a copy of the GNU Library General Public *
* License along with this library; see the file COPYING.LIB. If not, *
* write to the Free Software Foundation, Inc., 59 Temple Place, *
* Suite 330, Boston, MA 02111-1307, USA *
* *
***************************************************************************/
#ifndef SONAVIGATIONDRAGGER_H
#define SONAVIGATIONDRAGGER_H
// Geometry resources and part names for this dragger:
// Resource Names: Part Names:
// rotTransTranslatorTranslator translator.translator
// rotTransTranslatorTranslatorActive
// translator.translatorActive
// rotTransTranslatorFeedback translator.feedback
// rotTransTranslatorFeedbackActive translator.feedbackActive
// rotTransRotatorRotator XRotator.rotator
// rotTransRotatorRotatorActive XRotator.rotatorActive
// rotTransRotatorFeedback XRotator.feedback
// rotTransRotatorFeedbackActive XRotator.feedbackActive
// (and similarly for parts of the YRotator and ZRotator)
#include <Inventor/draggers/SoDragger.h>
#include <Inventor/fields/SoSFRotation.h>
#include <Inventor/fields/SoSFVec3f.h>
#include <Inventor/sensors/SoFieldSensor.h>
//class TranslateRadialDragger;
class SoRotateCylindricalDragger;
class RotTransDragger : public SoDragger
{
SO_KIT_HEADER(RotTransDragger);
// Makes the dragger surround other objects
SO_KIT_CATALOG_ENTRY_HEADER(surroundScale);
// Keeps the dragger evenly sized in all 3 dimensions
SO_KIT_CATALOG_ENTRY_HEADER(antiSquish);
// The translating dragger...
SO_KIT_CATALOG_ENTRY_HEADER(translator);
// The X and Z rotators need to be turned so as to orient
// correctly. So create a separator part and put an
// SoRotation node and the dragger underneath.
SO_KIT_CATALOG_ENTRY_HEADER(XRotatorSep);
SO_KIT_CATALOG_ENTRY_HEADER(XRotatorRot);
SO_KIT_CATALOG_ENTRY_HEADER(XRotator);
SO_KIT_CATALOG_ENTRY_HEADER(YRotator);
SO_KIT_CATALOG_ENTRY_HEADER(ZRotatorSep);
SO_KIT_CATALOG_ENTRY_HEADER(ZRotatorRot);
SO_KIT_CATALOG_ENTRY_HEADER(ZRotator);
public:
// Constructor
RotTransDragger();
// These fields reflect state of the dragger at all times.
SoSFRotation rotation;
SoSFVec3f translation;
// This should be called once after SoInteraction::init().
static void initClass();
protected:
// These sensors ensure that the motionMatrix is updated
// when the fields are changed from outside.
SoFieldSensor *rotFieldSensor;
SoFieldSensor *translFieldSensor;
static void fieldSensorCB(void *, SoSensor *);
// This function is invoked by the child draggers when they
// change their value.
static void valueChangedCB(void *, SoDragger *);
// Called at the beginning and end of each dragging motion.
// Tells the "surroundScale" part to recalculate.
static void invalidateSurroundScaleCB(void *, SoDragger *);
// This will detach/attach the fieldSensor.
// It is called at the end of the constructor (to attach).
// and at the start/end of SoBaseKit::readInstance()
// and on the new copy at the start/end of SoBaseKit::copy()
// Returns the state of the node when this was called.
SbBool setUpConnections( SbBool onOff,
SbBool doItAlways = false) override;
// This allows us to specify that certain parts do not
// write out. We'll use this on the antiSquish and
// surroundScale parts.
void setDefaultOnNonWritingFields() override;
private:
static const char NavigationDraggerLayout[];
// Destructor.
~RotTransDragger() override;
};
#endif //SONAVIGATIONDRAGGER_H

View File

@@ -1,96 +0,0 @@
/***************************************************************************
* Copyright (c) 2011 Werner Mayer <wmayer[at]users.sourceforge.net> *
* *
* This file is part of the FreeCAD CAx development system. *
* *
* This library is free software; you can redistribute it and/or *
* modify it under the terms of the GNU Library General Public *
* License as published by the Free Software Foundation; either *
* version 2 of the License, or (at your option) any later version. *
* *
* This library is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
* GNU Library General Public License for more details. *
* *
* You should have received a copy of the GNU Library General Public *
* License along with this library; see the file COPYING.LIB. If not, *
* write to the Free Software Foundation, Inc., 59 Temple Place, *
* Suite 330, Boston, MA 02111-1307, USA *
* *
***************************************************************************/
const char RotTransDragger::NavigationDraggerLayout[] =
"\n"
"\n"
"# Geometry resource file for the RotTransDragger\n"
"\n"
"# Geometry for the rotating parts.\n"
"DEF rotTransRotatorRotator Separator {\n"
" Material { \n"
" diffuseColor .05 .18 .125\n"
" emissiveColor .05 .18 .125\n"
" }\n"
" DrawStyle { lineWidth 2 }\n"
" Cylinder {\n"
" radius 1.85\n"
" height .15\n"
" parts SIDES\n"
" }\n"
"}\n"
"\n"
"DEF rotTransRotatorRotatorActive Separator {\n"
" Material { \n"
" diffuseColor .05 .2025 .18\n"
" emissiveColor .05 .2025 .18\n"
" }\n"
" DrawStyle { lineWidth 2 }\n"
" Cylinder {\n"
" radius 1.85\n"
" height .15\n"
" parts SIDES\n"
" }\n"
"}\n"
"\n"
"# Do not display the axis feedback used\n"
"# by the cylinder manips.\n"
"DEF rotTransRotatorFeedback Separator { }\n"
"DEF rotTransRotatorFeedbackActive Separator { }\n"
"\n"
"DEF rotTransTranslatorTranslator Separator {\n"
" Material { diffuseColor .6 .6 .6 }\n"
" DrawStyle { style LINES }\n"
" Sphere { radius 1.732 }\n"
"}\n"
"\n"
"DEF rotTransTranslatorTranslatorActive Separator {\n"
" Material { diffuseColor .6 .6 0 }\n"
" DrawStyle { style LINES }\n"
" Sphere { radius 1.732 }\n"
"}\n"
"\n"
"# Don't show anything for feedback during inactive state.\n"
"DEF rotTransTranslatorFeedback Separator { }\n"
"\n"
"DEF rotTransTranslatorFeedbackActive Separator {\n"
" Material { diffuseColor .5 .9 .9 }\n"
" # An arrow aligned with the x-axis.\n"
" RotationXYZ {\n"
" axis Z\n"
" angle 1.57079\n"
" }\n"
" Separator {\n"
"\n"
" #stick\n"
" Cylinder { height 4.0 radius 0.05 }\n"
"\n"
" #left arrowhead\n"
" Translation { translation 0 2.2 0 }\n"
" Cone { height 0.4 bottomRadius 0.2 }\n"
"\n"
" #right arrowhead\n"
" Translation { translation 0 -4.4 0 }\n"
" RotationXYZ { axis Z angle 3.14159 }\n"
" Cone { height 0.4 bottomRadius 0.2 }\n"
" }\n"
"}\n";

View File

@@ -1,73 +0,0 @@
#Inventor V2.0 ascii
# Geometry resource file for the RotTransDragger
# Geometry for the rotating parts.
DEF rotTransRotatorRotator Separator {
Material {
diffuseColor .05 .18 .125
emissiveColor .05 .18 .125
}
DrawStyle { lineWidth 2 }
Cylinder {
radius 1.85
height .15
parts SIDES
}
}
DEF rotTransRotatorRotatorActive Separator {
Material {
diffuseColor .05 .2025 .18
emissiveColor .05 .2025 .18
}
DrawStyle { lineWidth 2 }
Cylinder {
radius 1.85
height .15
parts SIDES
}
}
# Do not display the axis feedback used
# by the cylinder manips.
DEF rotTransRotatorFeedback Separator { }
DEF rotTransRotatorFeedbackActive Separator { }
DEF rotTransTranslatorTranslator Separator {
Material { diffuseColor .6 .6 .6 }
DrawStyle { style LINES }
Sphere { radius 1.732 }
}
DEF rotTransTranslatorTranslatorActive Separator {
Material { diffuseColor .6 .6 0 }
DrawStyle { style LINES }
Sphere { radius 1.732 }
}
# Don't show anything for feedback during inactive state.
DEF rotTransTranslatorFeedback Separator { }
DEF rotTransTranslatorFeedbackActive Separator {
Material { diffuseColor .5 .9 .9 }
# An arrow aligned with the x-axis.
RotationXYZ {
axis Z
angle 1.57079
}
Separator {
#stick
Cylinder { height 4.0 radius 0.05 }
#left arrowhead
Translation { translation 0 2.2 0 }
Cone { height 0.4 bottomRadius 0.2 }
#right arrowhead
Translation { translation 0 -4.4 0 }
RotationXYZ { axis Z angle 3.14159 }
Cone { height 0.4 bottomRadius 0.2 }
}
}