00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014 #ifndef __SIM_PointPosition_h__
00015 #define __SIM_PointPosition_h__
00016
00017 #include <SIM/SIM_Motion.h>
00018 #include "SIMZ_Utils.h"
00019
00020 class SIM_PointInfo;
00021
00022
00023
00024 class SIMZ_API SIM_PointPosition : public SIM_Motion
00025 {
00026 public:
00027
00028 GETSET_DATA_FUNCS_F(SIM_NAME_TIME, Time);
00029 GETSET_DATA_FUNCS_S(SIM_NAME_SOPPATH, SopPath);
00030 GETSET_DATA_FUNCS_B(SIM_NAME_USETRANSFORM, UseTransform);
00031 GETSET_DATA_FUNCS_S(SIM_NAME_POINTGROUP, PointGroup);
00032 GETSET_DATA_FUNCS_I(SIM_NAME_POINTINDEX, PointIndex);
00033 GETSET_DATA_FUNCS_S(SIM_NAME_EXTRAATTRIBUTES, ExtraAttributes);
00034 GETSET_DATA_FUNCS_B(SIM_NAME_ROTATETONORMAL, RotateToNormal);
00035
00036
00037
00038
00039
00040 void calculateValuesFromPoint(const UT_Vector3 &prevpos,
00041 const UT_Quaternion &prevrot,
00042 fpreal prevtime);
00043
00044 protected:
00045 explicit SIM_PointPosition(const SIM_DataFactory *factory);
00046 virtual ~SIM_PointPosition();
00047
00048 virtual void initializeSubclass();
00049 virtual void setParametersSubclass(const SIM_Options &parms);
00050
00051 private:
00052
00053 GETSET_DATA_FUNCS_B(SIM_NAME_HASHADPARMSSET, HasHadParmsSet);
00054
00055 void getPointInformation(SIM_PointInfo &info);
00056 static const SIM_DopDescription *getPointPositionDopDescription();
00057
00058 DECLARE_STANDARD_GETCASTTOTYPE();
00059 DECLARE_DATAFACTORY(SIM_PointPosition,
00060 SIM_Motion,
00061 "Point Position",
00062 getPointPositionDopDescription());
00063 };
00064
00065 #endif
00066