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