00001 #ifndef XDKWRL_NORMALINTERPOLATOR_H
00002 #define XDKWRL_NORMALINTERPOLATOR_H
00003
00004 #include <xdkwrl/config.h>
00005 #include <xdkwrl/node.h>
00006 #include <xdkwrl/fieldtypes/mffloat.h>
00007 #include <xdkwrl/fieldtypes/mfvec3f.h>
00008 #include <xdkwrl/fieldtypes/sffloat.h>
00009
00010 namespace wrl
00011 {
00012
00013
00014
00015 class XDKWRL_EXPORT NormalInterpolator : public Node
00016 {
00017 public:
00018 NormalInterpolator(const char* name="");
00019 virtual ~NormalInterpolator();
00020 virtual inline unsigned int nbFields() const;
00021 virtual FieldHandle field(const std::string& n);
00022 virtual FieldHandle field(unsigned int i);
00023 virtual bool isSetToDefaultValue(unsigned int i) const;
00024 virtual inline unsigned int nbEventsIn() const;
00025 virtual EventInHandle eventIn(const std::string& n);
00026 virtual EventInHandle eventIn(unsigned int i);
00027 virtual inline unsigned int nbEventsOut() const;
00028 virtual EventOutHandle eventOut(const std::string& n);
00029 virtual EventOutHandle eventOut(unsigned int i);
00030 inline const char* typeName() const;
00031 virtual Node* duplicate() const;
00032 virtual Node* duplicate(std::map<const Node*,Node*>&) const;
00033
00034
00035
00036
00037
00038
00039
00040
00041
00042
00043
00044 MFFloat key;
00045
00046
00047
00048
00049
00050 MFVec3f keyValue;
00051
00052
00053
00054
00055
00056
00057
00058
00059
00060
00061
00062
00063
00064
00065
00066
00067 EventIn<SFFloat> set_fraction;
00068
00069
00070
00071 EventIn<MFFloat> set_key;
00072
00073
00074
00075 EventIn<MFVec3f> set_keyValue;
00076
00077
00078
00079
00080
00081
00082
00083
00084
00085 EventOut<MFVec3f> value_changed;
00086
00087
00088
00089 EventOut<MFFloat> key_changed;
00090
00091
00092
00093 EventOut<MFVec3f> keyValue_changed;
00094
00095 };
00096 };
00097
00098
00099
00100
00101
00102
00103 inline const char*
00104 wrl::NormalInterpolator::typeName() const
00105 {
00106 return "NormalInterpolator";
00107 }
00108
00109
00110
00111 inline unsigned int
00112 wrl::NormalInterpolator::nbFields() const
00113 {
00114 return 2;
00115 }
00116
00117
00118
00119 inline unsigned int
00120 wrl::NormalInterpolator::nbEventsIn() const
00121 {
00122 return 1;
00123 }
00124
00125
00126
00127 inline unsigned int
00128 wrl::NormalInterpolator::nbEventsOut() const
00129 {
00130 return 1;
00131 }
00132 #endif // XDKWRL_NORMALINTERPOLATOR_H
00133
00134
00135
00136
00137
00138