00001 
00004 #ifndef _FBXSDK_WEIGHTED_MAPPING_H_
00005 #define _FBXSDK_WEIGHTED_MAPPING_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 <kaydaradef.h>
00043 #ifndef KFBX_DLL 
00044     #define KFBX_DLL K_DLLIMPORT
00045 #endif
00046 
00047 #include <kaydara.h>
00048 
00049 #include <klib/karrayul.h>
00050 
00051 #ifndef MB_FBXSDK
00052 #include <kbaselib_nsuse.h>
00053 #endif
00054 
00055 #include <fbxfilesdk_nsbegin.h>
00056 
00057 
00061 class KFBX_DLL KFbxWeightedMapping
00062 {
00063 
00064 public:
00065 
00066     typedef enum 
00067     {
00068         eSOURCE,
00069         eDESTINATION
00070     } ESet;
00071 
00072     struct KElement
00073     {
00074         int mIndex;
00075         double mWeight;
00076     };
00077 
00082 
00087     KFbxWeightedMapping(int pSourceSize, int pDestinationSize);
00088 
00090     ~KFbxWeightedMapping();
00092 
00093 
00098     void Reset(int pSourceSize, int pDestinationSize);
00099 
00105     void Add(int pSourceIndex, int pDestinationIndex, double pWeight);
00106 
00110     int GetElementCount(ESet pSet);
00111 
00116     int GetRelationCount(ESet pSet, int pElement);
00117 
00124     KElement& GetRelation(ESet pSet, int pElement, int pIndex);
00125 
00133     int GetRelationIndex(ESet pSet, int pElementInSet, int pElementInOtherSet);
00134 
00141     double GetRelationSum(ESet pSet, int pElement, bool pAbsoluteValue);
00142     
00143 
00148     void Normalize(ESet pSet, bool pAbsoluteValue);
00149     
00150 private:
00151 
00153     void Clear();
00154 
00155     KArrayTemplate<KArrayTemplate<KElement>*> mElements[2];
00156 
00157 };      
00158 
00159 typedef class KFBX_DLL KArrayTemplate<KFbxWeightedMapping::KElement> KArrayTemplateKElement;
00160 typedef class KFBX_DLL KArrayTemplate<KArrayTemplate<KFbxWeightedMapping::KElement>*> KArrayTemplateKArrayTemplateKElement;
00161 typedef KFbxWeightedMapping* HKFbxWeightedMapping;
00162 
00163 #include <fbxfilesdk_nsend.h>
00164 
00165 #endif 
00166 
00167