00001
00004 #ifndef FBXFILESDK_KFBXPLUGINS_KFBXWEIGHTEDMAPPING_H
00005 #define FBXFILESDK_KFBXPLUGINS_KFBXWEIGHTEDMAPPING_H
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038
00039
00040
00041 #include <fbxfilesdk/fbxfilesdk_def.h>
00042
00043 #include <fbxfilesdk/components/kbaselib/klib/karrayul.h>
00044
00045 #include <fbxfilesdk/fbxfilesdk_nsbegin.h>
00046
00050 class KFBX_DLL KFbxWeightedMapping
00051 {
00052
00053 public:
00054
00055 typedef enum
00056 {
00057 eSOURCE,
00058 eDESTINATION
00059 } ESet;
00060
00061 struct KElement
00062 {
00063 int mIndex;
00064 double mWeight;
00065 };
00066
00071
00076 KFbxWeightedMapping(int pSourceSize, int pDestinationSize);
00077
00079 ~KFbxWeightedMapping();
00081
00082
00087 void Reset(int pSourceSize, int pDestinationSize);
00088
00094 void Add(int pSourceIndex, int pDestinationIndex, double pWeight);
00095
00099 int GetElementCount(ESet pSet) const;
00100
00105 int GetRelationCount(ESet pSet, int pElement) const;
00106
00113 KElement& GetRelation(ESet pSet, int pElement, int pIndex);
00114
00122 int GetRelationIndex(ESet pSet, int pElementInSet, int pElementInOtherSet) const;
00123
00130 double GetRelationSum(ESet pSet, int pElement, bool pAbsoluteValue) const;
00131
00132
00137 void Normalize(ESet pSet, bool pAbsoluteValue);
00138
00139 private:
00140
00142 void Clear();
00143
00144 KArrayTemplate<KArrayTemplate<KElement>*> mElements[2];
00145
00146 };
00147
00148 typedef class KFBX_DLL KArrayTemplate<KFbxWeightedMapping::KElement> KArrayTemplateKElement;
00149 typedef class KFBX_DLL KArrayTemplate<KArrayTemplate<KFbxWeightedMapping::KElement>*> KArrayTemplateKArrayTemplateKElement;
00150 typedef KFbxWeightedMapping* HKFbxWeightedMapping;
00151
00152 #include <fbxfilesdk/fbxfilesdk_nsend.h>
00153
00154 #endif
00155