fixed: auto_ptr -> unique_ptr
[opensg.git] / Source / System / Dynamics / VRMLAnimation / OSGVRMLPositionInterpolator.cpp
blob9fb9964d3039ab0dc7f53f07a576166b7f3aebcd
1 /*---------------------------------------------------------------------------*\
2 * OpenSG *
3 * *
4 * *
5 * Copyright (C) 2000-2006 by the OpenSG Forum *
6 * *
7 * www.opensg.org *
8 * *
9 * contact: dirk@opensg.org, gerrit.voss@vossg.org, jbehr@zgdv.de *
10 * *
11 \*---------------------------------------------------------------------------*/
12 /*---------------------------------------------------------------------------*\
13 * License *
14 * *
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. *
18 * *
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. *
23 * *
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. *
27 * *
28 \*---------------------------------------------------------------------------*/
29 /*---------------------------------------------------------------------------*\
30 * Changes *
31 * *
32 * *
33 * *
34 * *
35 * *
36 * *
37 \*---------------------------------------------------------------------------*/
39 //---------------------------------------------------------------------------
40 // Includes
41 //---------------------------------------------------------------------------
43 #include <cstdlib>
44 #include <cstdio>
46 #include "OSGConfig.h"
48 #include "OSGVRMLPositionInterpolator.h"
49 #include "OSGInterpolationHelper.h"
51 OSG_BEGIN_NAMESPACE
53 // Documentation for this class is emitted in the
54 // OSGVRMLPositionInterpolatorBase.cpp file.
55 // To modify it, please change the .fcd file (OSGVRMLPositionInterpolator.fcd)
56 // and regenerate the base file.
58 /***************************************************************************\
59 * Class variables *
60 \***************************************************************************/
62 /***************************************************************************\
63 * Class methods *
64 \***************************************************************************/
66 void VRMLPositionInterpolator::initMethod(InitPhase ePhase)
68 Inherited::initMethod(ePhase);
70 if(ePhase == TypeObject::SystemPost)
76 /***************************************************************************\
77 * Instance methods *
78 \***************************************************************************/
80 /*-------------------------------------------------------------------------*\
81 - private -
82 \*-------------------------------------------------------------------------*/
84 /*----------------------- constructors & destructors ----------------------*/
86 VRMLPositionInterpolator::VRMLPositionInterpolator(void) :
87 Inherited()
91 VRMLPositionInterpolator::VRMLPositionInterpolator(
92 const VRMLPositionInterpolator &source) :
94 Inherited(source)
98 VRMLPositionInterpolator::~VRMLPositionInterpolator(void)
102 /*----------------------------- class specific ----------------------------*/
104 void VRMLPositionInterpolator::changed(ConstFieldMaskArg whichField,
105 UInt32 origin,
106 BitVector details)
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,
117 MFVec3f,
118 SFVec3f>::resortKeyValues(
119 _mfKey.size(),
120 uiNumRes,
121 *(this->editMFKeyValue()),
122 _mfResortIndex);
124 InterpolationHelper<MFReal32,
125 MFVec3f,
126 SFVec3f>::interpolate(
127 _sfInValue.getValue(),
128 _mfKey,
129 _mfKeyValue,
130 *(this->editSFOutValue()));
132 else
134 fprintf(stderr,
135 "interpol resort : sizes don't match %" PRISize " | %d\n",
136 uiNumRes, _mfResortIndex.size32());
140 if(0x0000 != (whichField & InValueFieldMask))
142 InterpolationHelper<MFReal32,
143 MFVec3f,
144 SFVec3f>::interpolate(
145 _sfInValue.getValue(),
146 _mfKey,
147 _mfKeyValue,
148 *(this->editSFOutValue()));
151 Inherited::changed(whichField, origin, details);
154 void VRMLPositionInterpolator::dump( UInt32 ,
155 const BitVector ) const
157 SLOG << "Dump VRMLPositionInterpolator NI" << std::endl;
160 void VRMLPositionInterpolator::evaluate(void)
162 InterpolationHelper<MFReal32, MFVec3f, SFVec3f>::interpolate(
163 _sfInValue.getValue(),
164 _mfKey,
165 _mfKeyValue,
166 *(this->editSFOutValue()));
169 OSG_END_NAMESPACE