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
00042 #include <fbxfilesdk/components/kbaselib/kaydaradef_h.h>
00043 #include <fbxfilesdk/components/kbaselib/kaydara.h>
00044
00045 #include <fbxfilesdk/components/kbaselib/klib/karrayul.h>
00046
00047 #include <fbxfilesdk/fbxfilesdk_nsbegin.h>
00048
00049
00053 class KFBX_DLL KFbxWeightedMapping
00054 {
00055
00056 public:
00057
00058 typedef enum
00059 {
00060 eSOURCE,
00061 eDESTINATION
00062 } ESet;
00063
00064 struct KElement
00065 {
00066 int mIndex;
00067 double mWeight;
00068 };
00069
00074
00079 KFbxWeightedMapping(int pSourceSize, int pDestinationSize);
00080
00082 ~KFbxWeightedMapping();
00084
00085
00090 void Reset(int pSourceSize, int pDestinationSize);
00091
00097 void Add(int pSourceIndex, int pDestinationIndex, double pWeight);
00098
00102 int GetElementCount(ESet pSet);
00103
00108 int GetRelationCount(ESet pSet, int pElement);
00109
00116 KElement& GetRelation(ESet pSet, int pElement, int pIndex);
00117
00125 int GetRelationIndex(ESet pSet, int pElementInSet, int pElementInOtherSet);
00126
00133 double GetRelationSum(ESet pSet, int pElement, bool pAbsoluteValue);
00134
00135
00140 void Normalize(ESet pSet, bool pAbsoluteValue);
00141
00142 private:
00143
00145 void Clear();
00146
00147 KArrayTemplate<KArrayTemplate<KElement>*> mElements[2];
00148
00149 };
00150
00151 typedef class KFBX_DLL KArrayTemplate<KFbxWeightedMapping::KElement> KArrayTemplateKElement;
00152 typedef class KFBX_DLL KArrayTemplate<KArrayTemplate<KFbxWeightedMapping::KElement>*> KArrayTemplateKArrayTemplateKElement;
00153 typedef KFbxWeightedMapping* HKFbxWeightedMapping;
00154
00155 #include <fbxfilesdk/fbxfilesdk_nsend.h>
00156
00157 #endif
00158