13
#pragma comment(lib, "Irrlicht.lib")
16
void usage(const char* name)
18
std::cerr << "Usage: " << name << " [options] <srcFile> <destFile>" << std::endl;
19
std::cerr << " where options are" << std::endl;
20
std::cerr << " --createTangents: convert to tangents mesh is possible." << std::endl;
21
std::cerr << " --format=[irrmesh|collada|stl|obj|ply]: Choose target format" << std::endl;
24
int main(int argc, char* argv[])
27
((argc==3) && (argv[1][0]=='-')))
33
IrrlichtDevice *device = createDevice( video::EDT_NULL,
34
dimension2d<u32>(800, 600), 32, false, false, false, 0);
36
device->setWindowCaption(L"Mesh Converter");
38
scene::EMESH_WRITER_TYPE type = EMWT_IRR_MESH;
40
bool createTangents=false;
41
while (argv[i][0]=='-')
43
core::stringc format = argv[i];
44
if (format.size() > 3)
46
if (format.equalsn("--format=",9))
48
format = format.subString(9,format.size());
49
if (format=="collada")
51
else if (format=="stl")
53
else if (format=="obj")
55
else if (format=="ply")
61
if (format =="--createTangents")
73
const s32 srcmesh = i;
74
const s32 destmesh = i+1;
77
if ((argc<srcmesh) || (argc<destmesh))
79
std::cerr << "Not enough files given." << std::endl;
84
createTangents = createTangents && (type==EMWT_IRR_MESH);
85
std::cout << "Converting " << argv[srcmesh] << " to " << argv[destmesh] << std::endl;
86
IMesh* mesh = device->getSceneManager()->getMesh(argv[srcmesh])->getMesh(0);
89
std::cerr << "Could not load " << argv[srcmesh] << std::endl;
94
IMesh* tmp = device->getSceneManager()->getMeshManipulator()->createMeshWithTangents(mesh);
98
IMeshWriter* mw = device->getSceneManager()->createMeshWriter(type);
99
IWriteFile* file = device->getFileSystem()->createAndWriteFile(argv[destmesh]);
100
mw->writeMesh(file, mesh);