1#ifndef __JBXL_CONTOUR_BASE_H_
2#define __JBXL_CONTOUR_BASE_H_
51 ContourTriIndex(
int w1=0,
int w2=0,
int w3=0,
int m1=0,
int m2=0,
int m3=0) {
init(w1,w2,w3,m1,m2,m3);}
54 void init(
int w1=0,
int w2=0,
int w3=0,
int m1=0,
int m2=0,
int m3=0,
int u1=0,
int u2=0,
int u3=0) {
set(w1,w2,w3,m1,m2,m3,u1,u2,u3);}
55 void set (
int w1=0,
int w2=0,
int w3=0,
int m1=0,
int m2=0,
int m3=0,
int u1=0,
int u2=0,
int u3=0);
56 void mlt_set(
int d1=0,
int d2=0,
int d3=0);
95 void execScale(
double x,
double y,
double z);
137TriPolygonData*
joinTriPolygonData(TriPolygonData*& first,
int num_f, TriPolygonData*& next,
int num_n);
166 void init(
int idx=0,
int num=0);
200 void init(
int num=0);
ContourBaseData(int idx=0, int num=0)
int num_data
データ数.(vertex, normal, texcrd, weight の要素数)
virtual ~ContourBaseData(void)
void dup(ContourBaseData a)
void execRotate(Quaternion< double > quat)
UVMap< double > * texcrd
テクスチャマップ texcrd[index[0]], texcrd[index[1]], texcrd[index[2]], ... の順に並ぶ
int num_index
インデックスの数.(index の要素数)
Vector< double > * vertex
頂点データ vertex[index[0]], vertex[index[1]], vertex[index[2]], ... の順に並ぶ
void execScale(Vector< double > scale)
void execShift(Vector< double > shift)
ArrayParam< int > * weight
Skin の Weight weight[index[0]], weight[index[1]], weight[index[2]], ... の順に並ぶ
Vector< double > * normal
法線ベクトル normal[index[0]], normal[index[1]], normal[index[2]], ... の順に並ぶ
void init(int idx=0, int num=0)
void execShift(double x, double y, double z)
void execScale(double x, double y, double z)
void execRotate(Quaternion< double > q)
virtual ~ContourTriData(void)
virtual ~ContourTriIndex(void)
void mlt_set(int d1=0, int d2=0, int d3=0)
Vector< float > SurfaceNormal(CONTOUR_VECTOR_ARRAY32 *coords)
void init(int w1=0, int w2=0, int w3=0, int m1=0, int m2=0, int m3=0, int u1=0, int u2=0, int u3=0)
ContourTriIndex(int w1=0, int w2=0, int w3=0, int m1=0, int m2=0, int m3=0)
Vector< double > SurfaceNormal(CONTOUR_VECTOR_ARRAY *coords)
void set(int w1=0, int w2=0, int w3=0, int m1=0, int m2=0, int m3=0, int u1=0, int u2=0, int u3=0)
virtual ~SkinJointData(void)
AffineTrans< double > bind_shape
AffineTrans< double > * alt_inverse_bind
AffineTrans< double > * inverse_bind
ArrayParam< char * > joint_names
Joint名の配列.
ArrayParam< int > weight[3]
void execRotate(Quaternion< double > quat)
Vector< double > vertex[3]
bool has_weight
配列データの場合,一番最初のデータが値を持っていれば十分である.
bool has_normal
配列データの場合,一番最初のデータが値を持っていれば十分である.
void execScale(Vector< double > scale)
bool has_texcrd
配列データの場合,一番最初のデータが値を持っていれば十分である.
void dup(TriPolygonData a)
void execShift(Vector< double > shift)
virtual ~TriPolygonData(void)
UVMap< double > texcrd[3]
Vector< double > normal[3]
Vector< T > normalize(void)
TriPolygonData * dupTriPolygonData(TriPolygonData *data, int num)
void freeContourBaseData(ContourBaseData *&contour)
std::vector< Vector< float > > CONTOUR_VECTOR_ARRAY32
std::vector< ContourTriData > CONTOUR_TRIDATA_ARRAY
std::vector< Vector< double > > CONTOUR_VECTOR_ARRAY
TriPolygonData * joinTriPolygonData(TriPolygonData *&first, int num_f, TriPolygonData *&next, int num_n)
Vector< T > NewellMethod(Vector< T > v1, Vector< T > v2, Vector< T > v3)
Normal Vector of 3 Vectors with Newell Mothod.
void freeTriPolygonData(TriPolygonData *&tridata)
std::vector< ContourTriIndex > CONTOUR_TRIINDX_ARRAY