1 /*---------------------------------------------------------------------------*\
5 * Copyright (C) 2000-2006 by the OpenSG Forum *
9 * contact: dirk@opensg.org, gerrit.voss@vossg.org, jbehr@zgdv.de *
11 \*---------------------------------------------------------------------------*/
12 /*---------------------------------------------------------------------------*\
15 * This library is free software; you can redistribute it and/or modify it *
16 * under the terms of the GNU Library General Public License as published *
17 * by the Free Software Foundation, version 2. *
19 * This library is distributed in the hope that it will be useful, but *
20 * WITHOUT ANY WARRANTY; without even the implied warranty of *
21 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU *
22 * Library General Public License for more details. *
24 * You should have received a copy of the GNU Library General Public *
25 * License along with this library; if not, write to the Free Software *
26 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. *
28 \*---------------------------------------------------------------------------*/
29 /*---------------------------------------------------------------------------*\
37 \*---------------------------------------------------------------------------*/
39 //---------------------------------------------------------------------------
41 //---------------------------------------------------------------------------
46 #include "OSGConfig.h"
48 #include "OSGVRMLOrientationInterpolator.h"
49 #include "OSGInterpolationHelper.h"
53 // Documentation for this class is emitted in the
54 // OSGVRMLOrientationInterpolatorBase.cpp file.
55 // To modify it, please change the .fcd file
56 // (OSGVRMLOrientationInterpolator.fcd) and regenerate the base file.
58 /***************************************************************************\
60 \***************************************************************************/
62 /***************************************************************************\
64 \***************************************************************************/
66 void VRMLOrientationInterpolator::initMethod(InitPhase ePhase
)
68 Inherited::initMethod(ePhase
);
70 if(ePhase
== TypeObject::SystemPost
)
76 /***************************************************************************\
78 \***************************************************************************/
80 /*-------------------------------------------------------------------------*\
82 \*-------------------------------------------------------------------------*/
84 /*----------------------- constructors & destructors ----------------------*/
86 VRMLOrientationInterpolator::VRMLOrientationInterpolator(void) :
91 VRMLOrientationInterpolator::VRMLOrientationInterpolator(
92 const VRMLOrientationInterpolator
&source
) :
98 VRMLOrientationInterpolator::~VRMLOrientationInterpolator(void)
102 /*----------------------------- class specific ----------------------------*/
104 void VRMLOrientationInterpolator::changed(ConstFieldMaskArg whichField
,
108 if(0x0000 != (whichField
& ResortIndexFieldMask
))
110 fprintf(stderr
, "resort triggert\n");
112 SizeT uiNumRes
= _mfKeyValue
.size() / _mfKey
.size();
114 if(uiNumRes
== _mfResortIndex
.size())
116 InterpolationHelper
<MFReal32
,
118 SFQuaternion
>::resortKeyValues(
121 *(this->editMFKeyValue()),
124 InterpolationHelper
<MFReal32
,
126 SFQuaternion
>::interpolate(
127 _sfInValue
.getValue(),
130 *(this->editSFOutValue()));
135 "interpol resort : sizes don't match %" PRISize
" | %d\n",
136 uiNumRes
, _mfResortIndex
.size32());
140 if(0x0000 != (whichField
& InValueFieldMask
))
142 InterpolationHelper
<MFReal32
,
144 SFQuaternion
>::interpolate(
145 _sfInValue
.getValue(),
148 *(this->editSFOutValue()));
151 Inherited::changed(whichField
, origin
, details
);
154 void VRMLOrientationInterpolator::dump( UInt32
,
155 const BitVector
) const
157 SLOG
<< "Dump VRMLOrientationInterpolator NI" << std::endl
;
160 void VRMLOrientationInterpolator::evaluate(void)
162 InterpolationHelper
<MFReal32
, MFQuaternion
, SFQuaternion
>::interpolate(
163 _sfInValue
.getValue(),
166 *(this->editSFOutValue()));