JunkBox_Lib++ (for Windows) 1.10.1
Loading...
Searching...
No Matches
FBXDataTool.cpp
Go to the documentation of this file.
1
7#include "FBXDataTool.h"
8
9
10using namespace jbxl;
11
12
14//
15
17{
18 DEBUG_MODE PRINT_MESG("FBXData::DESTRUCTOR:\n");
19 this->free();
20}
21
22
23void FBXData::init(void)
24{
25 this->fbx_name = init_Buffer();
26 this->phantom_out = true;
27 this->no_offset = false;
28
29 this->has_joints = false;
30 this->joints_list = NULL;
31
32 this->forUnity = true;
33 this->forUE = false;
34
36 this->affineTrans = NULL;
37 this->skeleton.init();
38}
39
40
41void FBXData::free(void)
42{
43 free_Buffer(&(this->fbx_name));
44 this->skeleton.free();
45 this->delAffineTrans();
46 this->affineTrans = NULL;
47
48 if (this->joints_list!=NULL) del_tList(&this->joints_list);
49 this->joints_list = NULL;
50}
51
52
54{
55 this->setUnity(false);
56 this->setUE(false);
57 //
58 this->engine = e;
59 if (e==JBXL_3D_ENGINE_UNITY) this->setUnity(true);
60 else if (e==JBXL_3D_ENGINE_UE) this->setUE(true);
61
62 return;
63}
64
65
66//void FBXData::outputFile(const char* fname, const char* out_dirn, const char* ptm_dirn, const char* tex_dirn, const char* bin_dirn)
67void FBXData::outputFile(const char* fname, const char* out_dirn, const char* tex_dirn, const char* bin_dirn)
68{
69 UNUSED(out_dirn);
70 UNUSED(tex_dirn);
71 UNUSED(bin_dirn);
72
73 char* packname = pack_head_tail_char(get_file_name(fname), ' ');
74 Buffer file_name = make_Buffer_bystr(packname);
75 ::free(packname);
76 //
78 if (file_name.buf[0]=='.') file_name.buf[0] = '_';
79
80 free_Buffer(&file_name);
81 return;
82}
83
84
86
87void FBXData::addShell(MeshObjectData* meshdata, bool collider, SkinJointData* joints_data, tList* joints_template)
88{
89 //PRINT_MESG("FBXData::addShell: start\n");
90
91 if (meshdata==NULL) return;
92
93 if (joints_data!=NULL && joints_template!=NULL) {
94 if (this->joints_list==NULL && !this->has_joints) {
95 this->joints_list = joints_template;
96 this->has_joints = true;
97 }
98 else {
99 if (joints_template!=NULL) del_tList(&joints_template);
100 joints_template = NULL;
101 }
102 }
103
104 MeshFacetNode* facet = meshdata->facet;
105 while (facet!=NULL) {
106 if (facet->num_vertex != facet->num_texcrd) {
107 PRINT_MESG("FBXData::addShell: Error: missmatch vertex and uvmap number! (%d != %d)\n", facet->num_vertex, facet->num_texcrd);
108 facet = facet->next;
109 continue;
110 }
111
112 // UV Map and PLANAR Texture
114 Vector<double> scale(1.0, 1.0, 1.0);
115 if (meshdata->affineTrans!=NULL) scale = meshdata->affineTrans->getScale();
116 facet->generatePlanarUVMap(scale, facet->texcrd_value);
117 }
118 facet->execAffineTransUVMap(facet->texcrd_value, facet->num_vertex);
119
120 //facet->num_index;
121 //facet->num_vertex;
122
123 //int* index = facet->data_index;
124 //Vector<double>* vectr = facet->vertex_value;
125 //Vector<double>* norml = facet->normal_value;
126 //UVMap<double>* uvmap = facet->texcrd_value;
127
128 facet = facet->next;
129 }
130
131 //
132 this->phantom_out = true;
133 if (collider) {
134 this->phantom_out = false;
135 }
136
137 //
138 if (this->has_joints && this->joints_list!=NULL) {
139
140 }
141
142 return;
143}
144
145
153{
154 Vector<double> center(0.0, 0.0, 0.0);
155
156 if (this->no_offset) center = affineTrans->getShift();
157
158 return center;
159}
160
161
163{
164 if (fp==NULL) return;
165
166 return;
167}
168
#define MATERIAL_MAPPING_PLANAR
void free_Buffer(Buffer *buf)
Buffer型変数のバッファ部を解放する
Definition buffer.cpp:128
Buffer init_Buffer()
初期化したBuffer型変数を返す.
Definition buffer.cpp:47
#define make_Buffer_bystr(str)
set_Buffer()
Definition buffer.h:57
void init(void)
Definition AffineTrans.h:44
Vector< T > getScale(void)
void free(void)
Definition AffineTrans.h:49
Vector< T > getShift(void)
void setUE(bool b)
Definition FBXDataTool.h:53
Vector< double > execAffineTrans(void)
void init(void)
void delAffineTrans(void)
Definition FBXDataTool.h:57
void addShell(MeshObjectData *meshdata, bool collider, SkinJointData *joints_data=NULL, tList *joints_template=NULL)
AffineTrans< double > * affineTrans
Definition FBXDataTool.h:45
void outputFile(const char *fn, const char *out_dirn, const char *tex_dirn, const char *bin_dirn)
void free(void)
AffineTrans< double > skeleton
Definition FBXDataTool.h:46
void setEngine(int)
virtual ~FBXData(void)
void setUnity(bool b)
Definition FBXDataTool.h:52
Buffer fbx_name
Definition FBXDataTool.h:34
tList * joints_list
Definition FBXDataTool.h:43
void output_fbx(FILE *fp)
int mapping
マッピング方法
MeshObject の Polygonデータ(1面)を格納するクラス.リスト構造を取る.
MaterialParam material_param
マテリアルパラメータ
int num_texcrd
テクスチャ画像の座標数.通常は num_vertex に等しい.(texcrd_value の要素数)
void execAffineTransUVMap(UVMap< double > *uvmap=NULL, int num=-1)
UVMap< double > * texcrd_value
テクスチャマップの並び.要素数は num_texcrd
MeshFacetNode * next
UVMap< double > * generatePlanarUVMap(Vector< double > scale, UVMap< double > *uvmap=NULL)
int num_vertex
頂点のデータ数.(vertex_value, normal_value の要素数)
AffineTrans< double > * affineTrans
アフィン変換.ここで使用するのは,shift, rotate, scale(size) のみ
MeshFacetNode * facet
FACETデータ(1面のポリゴンデータ)のリストへのポインタ
#define JBXL_3D_ENGINE_UE
Definition common.h:311
#define UNUSED(x)
Definition common.h:264
#define TRUE
Definition common.h:226
#define JBXL_3D_ENGINE_UNITY
Definition common.h:310
Definition Brep.h:29
unsigned char * buf
バッファの先頭へのポインタ.str[bufsz]は必ず 0x00となる.
Definition buffer.h:39
tList * del_tList(tList **pp)
指定したリストノード以降のリストを削除.
Definition tlist.cpp:735
char * get_file_name(const char *str)
フルパスからファイル名へのポインタを取り出す.free() してはいけない.
Definition tools.cpp:2066
char * pack_head_tail_char(char *mesg, char cc)
文字の先頭のcc(複数),TAB, CR, LF.終わりのcc(複数),TAB, CR, LF を削除.要 free()
Definition tools.cpp:1092
#define PRINT_MESG(...)
環境依存用の出力関数.MS Windows用は未実装
Definition tools.h:469
#define DEBUG_MODE
Definition tools.h:502
void canonical_filename_Buffer(Buffer *fname, int no_dir)
fname の問題になりそうな ASCII文字を '_' に変換する.
Definition xtools.cpp:2057