200 for (
int i=0; i<3; i++) {
211 for (
int i=0; i<3; i++) {
225 for (
int i=0; i<3; i++) {
236 for (
int i=0; i<3; i++) {
246 for (
int i=0; i<3; i++) {
256 for (
int i=0; i<3; i++) {
269 if (data==NULL)
return NULL;
272 if (dup==NULL)
return NULL;
275 for (
int i=0; i<num; i++) {
277 for (
int j=0; j<3; j++) dup[i].weight[j].dup(data[i].weight[j]);
285 if (first==NULL)
return next;
286 if (next ==NULL)
return first;
289 if (join==NULL)
return NULL;
293 for (
int i=0; i<num_p; i++) {
294 join[i].
dup(first[i]);
295 if (join[i].polygonNum>num) num = join[i].
polygonNum;
299 for (
int i=0; i<num_n; i++) {
300 join[num_p+i].
dup(next[i]);
317 for (
int i=0; i<n; i++) {
void dup(ArrayParam< T > a, bool del=true)
int num_data
データ数.(vertex, normal, texcrd, weight の要素数)
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 execScale(double x, double y, double z)
void execRotate(Quaternion< double > q)
void mlt_set(int d1=0, int d2=0, int d3=0)
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)
Vector< T > execRotation(Vector< T > v)
Exec Rotation qv(~q)
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)
UVMap< double > texcrd[3]
Vector< double > normal[3]
TriPolygonData * dupTriPolygonData(TriPolygonData *data, int num)
Vector< T > VectorRotation(Vector< T > v, Quaternion< T > q)
TriPolygonData * joinTriPolygonData(TriPolygonData *&first, int num_f, TriPolygonData *&next, int num_n)
void freeTriPolygonData(TriPolygonData *&tridata)