123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250 |
- #include "3d/CCBundle3D.h"
- #include "3d/CCObjLoader.h"
- #include "base/ccMacros.h"
- #include "platform/CCFileUtils.h"
- #include "renderer/CCGLProgram.h"
- #include "3d/CCBundleReader.h"
- #include "base/CCData.h"
- #define BUNDLE_TYPE_SCENE 1
- #define BUNDLE_TYPE_NODE 2
- #define BUNDLE_TYPE_ANIMATIONS 3
- #define BUNDLE_TYPE_ANIMATION 4
- #define BUNDLE_TYPE_ANIMATION_CHANNEL 5
- #define BUNDLE_TYPE_MODEL 10
- #define BUNDLE_TYPE_MATERIAL 16
- #define BUNDLE_TYPE_EFFECT 18
- #define BUNDLE_TYPE_CAMERA 32
- #define BUNDLE_TYPE_LIGHT 33
- #define BUNDLE_TYPE_MESH 34
- #define BUNDLE_TYPE_MESHPART 35
- #define BUNDLE_TYPE_MESHSKIN 36
- static const char* VERSION = "version";
- static const char* ID = "id";
- static const char* DEFAULTPART = "body";
- static const char* VERTEXSIZE = "vertexsize";
- static const char* VERTEX = "vertex";
- static const char* VERTICES = "vertices";
- static const char* INDEXNUM = "indexnum";
- static const char* INDICES = "indices";
- static const char* SUBMESH = "submesh";
- static const char* ATTRIBUTES = "attributes";
- static const char* ATTRIBUTESIZE = "size";
- static const char* TYPE = "type";
- static const char* ATTRIBUTE = "attribute";
- static const char* SKIN = "skin";
- static const char* BINDSHAPE = "bindshape";
- static const char* MESH = "mesh";
- static const char* MESHES = "meshes";
- static const char* MESHPARTID = "meshpartid";
- static const char* MATERIALID = "materialid";
- static const char* NODE = "node";
- static const char* NODES = "nodes";
- static const char* CHILDREN = "children";
- static const char* PARTS = "parts";
- static const char* BONES = "bones";
- static const char* SKELETON = "skeleton";
- static const char* MATERIALS = "materials";
- static const char* ANIMATIONS = "animations";
- static const char* TRANSFORM = "transform";
- static const char* OLDTRANSFORM = "tansform";
- static const char* ANIMATION = "animation";
- static const char* MATERIAL = "material";
- static const char* BASE = "base";
- static const char* FILENAME = "filename";
- static const char* TEXTURES = "textures";
- static const char* LENGTH = "length";
- static const char* BONEID = "boneId";
- static const char* KEYFRAMES = "keyframes";
- static const char* TRANSLATION = "translation";
- static const char* ROTATION = "rotation";
- static const char* SCALE = "scale";
- static const char* KEYTIME = "keytime";
- static const char* AABBS = "aabb";
- NS_CC_BEGIN
- void getChildMap(std::map<int, std::vector<int> >& map, SkinData* skinData, const rapidjson::Value& val)
- {
- if (!skinData)
- return;
-
- Mat4 transform;
- const rapidjson::Value& parent_transform = val[OLDTRANSFORM];
- for (rapidjson::SizeType j = 0, size = parent_transform.Size(); j < size; ++j)
- {
- transform.m[j] = parent_transform[j].GetDouble();
- }
-
- std::string parent_name = val[ID].GetString();
- int parent_name_index = skinData->getSkinBoneNameIndex(parent_name);
- if (parent_name_index < 0)
- {
- skinData->addNodeBoneNames(parent_name);
- skinData->nodeBoneOriginMatrices.push_back(transform);
- parent_name_index = skinData->getBoneNameIndex(parent_name);
- }
- else if (parent_name_index < static_cast<int>(skinData->skinBoneNames.size()))
- {
- skinData->skinBoneOriginMatrices[parent_name_index] = transform;
- }
-
- if(skinData->rootBoneIndex < 0)
- skinData->rootBoneIndex = parent_name_index;
- if (!val.HasMember(CHILDREN))
- return;
- const rapidjson::Value& children = val[CHILDREN];
- for (rapidjson::SizeType i = 0, size = children.Size(); i < size; ++i)
- {
-
- const rapidjson::Value& child = children[i];
- std::string child_name = child[ID].GetString();
- int child_name_index = skinData->getSkinBoneNameIndex(child_name);
- if (child_name_index < 0)
- {
- skinData->addNodeBoneNames(child_name);
- child_name_index = skinData->getBoneNameIndex(child_name);
- }
- map[parent_name_index].push_back(child_name_index);
- getChildMap(map, skinData, child);
- }
- }
- Bundle3D* Bundle3D::createBundle()
- {
- auto bundle = new (std::nothrow) Bundle3D();
- return bundle;
- }
- void Bundle3D::destroyBundle(Bundle3D* bundle)
- {
- delete bundle;
- }
- void Bundle3D::clear()
- {
- if (_isBinary)
- {
- _binaryBuffer.clear();
- CC_SAFE_DELETE_ARRAY(_references);
- }
- else
- {
- _jsonBuffer.clear();
- }
- }
- bool Bundle3D::load(const std::string& path)
- {
- if (path.empty())
- return false;
-
- if (_path == path)
- return true;
- getModelRelativePath(path);
- bool ret = false;
- std::string ext = FileUtils::getInstance()->getFileExtension(path);
- if (ext == ".c3t")
- {
- _isBinary = false;
- ret = loadJson(path);
- }
- else if (ext == ".c3b")
- {
- _isBinary = true;
- ret = loadBinary(path);
- }
- else
- {
- CCLOG("warning: %s is invalid file formate", path.c_str());
- }
- ret?(_path = path):(_path = "");
- return ret;
- }
- bool Bundle3D::loadObj(MeshDatas& meshdatas, MaterialDatas& materialdatas, NodeDatas& nodedatas, const std::string& fullPath, const char* mtl_basepath)
- {
- meshdatas.resetData();
- materialdatas.resetData();
- nodedatas.resetData();
- std::string mtlPath = "";
- if (mtl_basepath)
- mtlPath = mtl_basepath;
- else
- mtlPath = fullPath.substr(0, fullPath.find_last_of("\\/") + 1);
-
- std::vector<tinyobj::shape_t> shapes;
- std::vector<tinyobj::material_t> materials;
- auto ret = tinyobj::LoadObj(shapes, materials, fullPath.c_str(), mtlPath.c_str());
- if (ret.empty())
- {
-
-
- int i = 0;
- char str[20];
- std::string dir = "";
- auto last = fullPath.rfind("/");
- if (last != std::string::npos)
- dir = fullPath.substr(0, last + 1);
- for (auto& material : materials) {
- NMaterialData materialdata;
-
- NTextureData tex;
- tex.filename = material.diffuse_texname.empty() ? material.diffuse_texname : dir + material.diffuse_texname;
- tex.type = NTextureData::Usage::Diffuse;
- tex.wrapS = GL_CLAMP_TO_EDGE;
- tex.wrapT = GL_CLAMP_TO_EDGE;
-
- sprintf(str, "%d", ++i);
- materialdata.textures.push_back(tex);
- materialdata.id = str;
- material.name = str;
- materialdatas.materials.push_back(materialdata);
- }
-
-
- i = 0;
- for (auto& shape : shapes) {
- auto mesh = shape.mesh;
- MeshData* meshdata = new (std::nothrow) MeshData();
- MeshVertexAttrib attrib;
- attrib.size = 3;
- attrib.type = GL_FLOAT;
-
- if (mesh.positions.size())
- {
- attrib.vertexAttrib = GLProgram::VERTEX_ATTRIB_POSITION;
- attrib.attribSizeBytes = attrib.size * sizeof(float);
- meshdata->attribs.push_back(attrib);
-
- }
- bool hasnormal = false, hastex = false;
- if (mesh.normals.size())
- {
- hasnormal = true;
- attrib.vertexAttrib = GLProgram::VERTEX_ATTRIB_NORMAL;
- attrib.attribSizeBytes = attrib.size * sizeof(float);
- meshdata->attribs.push_back(attrib);
- }
- if (mesh.texcoords.size())
- {
- hastex = true;
- attrib.size = 2;
- attrib.vertexAttrib = GLProgram::VERTEX_ATTRIB_TEX_COORD;
- attrib.attribSizeBytes = attrib.size * sizeof(float);
- meshdata->attribs.push_back(attrib);
- }
-
- auto vertexNum = mesh.positions.size() / 3;
- for(unsigned int k = 0; k < vertexNum; ++k)
- {
- meshdata->vertex.push_back(mesh.positions[k * 3]);
- meshdata->vertex.push_back(mesh.positions[k * 3 + 1]);
- meshdata->vertex.push_back(mesh.positions[k * 3 + 2]);
-
- if (hasnormal)
- {
- meshdata->vertex.push_back(mesh.normals[k * 3]);
- meshdata->vertex.push_back(mesh.normals[k * 3 + 1]);
- meshdata->vertex.push_back(mesh.normals[k * 3 + 2]);
- }
-
- if (hastex)
- {
- meshdata->vertex.push_back(mesh.texcoords[k * 2]);
- meshdata->vertex.push_back(mesh.texcoords[k * 2 + 1]);
- }
- }
-
-
- std::map<int, std::vector<unsigned short> > subMeshMap;
- for (size_t k = 0, size = mesh.material_ids.size(); k < size; ++k) {
- int id = mesh.material_ids[k];
- size_t idx = k * 3;
- subMeshMap[id].push_back(mesh.indices[idx]);
- subMeshMap[id].push_back(mesh.indices[idx + 1]);
- subMeshMap[id].push_back(mesh.indices[idx + 2]);
- }
-
- auto node = new (std::nothrow) NodeData();
- node->id = shape.name;
- for (auto& submesh : subMeshMap) {
- meshdata->subMeshIndices.push_back(submesh.second);
- meshdata->subMeshAABB.push_back(calculateAABB(meshdata->vertex, meshdata->getPerVertexSize(), submesh.second));
- sprintf(str, "%d", ++i);
- meshdata->subMeshIds.push_back(str);
-
- auto modelnode = new (std::nothrow) ModelData();
- modelnode->materialId = submesh.first == -1 ? "" : materials[submesh.first].name;
- modelnode->subMeshId = str;
- node->modelNodeDatas.push_back(modelnode);
- }
- nodedatas.nodes.push_back(node);
- meshdatas.meshDatas.push_back(meshdata);
- }
-
- return true;
- }
- CCLOG("warning: load %s file error: %s", fullPath.c_str(), ret.c_str());
- return false;
- }
- bool Bundle3D::loadSkinData(const std::string& , SkinData* skindata)
- {
- skindata->resetData();
- if (_isBinary)
- {
- return loadSkinDataBinary(skindata);
- }
- else
- {
- return loadSkinDataJson(skindata);
- }
- }
- bool Bundle3D::loadAnimationData(const std::string& id, Animation3DData* animationdata)
- {
- animationdata->resetData();
- if (_isBinary)
- {
- return loadAnimationDataBinary(id,animationdata);
- }
- else
- {
- return loadAnimationDataJson(id,animationdata);
- }
- }
- bool Bundle3D::loadMeshDatas(MeshDatas& meshdatas)
- {
- meshdatas.resetData();
- if (_isBinary)
- {
- if (_version == "0.1" || _version == "0.2")
- {
- return loadMeshDatasBinary_0_1(meshdatas);
- }
- else
- {
- return loadMeshDatasBinary(meshdatas);
- }
- }
- else
- {
- if (_version == "1.2" || _version == "0.2")
- {
- return loadMeshDataJson_0_1(meshdatas);
- }
- else
- {
- return loadMeshDatasJson(meshdatas);
- }
- }
- return true;
- }
- bool Bundle3D::loadMeshDatasBinary(MeshDatas& meshdatas)
- {
- if (!seekToFirstType(BUNDLE_TYPE_MESH))
- return false;
- unsigned int meshSize = 0;
- if (_binaryReader.read(&meshSize, 4, 1) != 1)
- {
- CCLOG("warning: Failed to read meshdata: attribCount '%s'.", _path.c_str());
- return false;
- }
- MeshData* meshData = nullptr;
- for(unsigned int i = 0; i < meshSize ; ++i)
- {
- unsigned int attribSize=0;
-
- if (_binaryReader.read(&attribSize, 4, 1) != 1 || attribSize < 1)
- {
- CCLOG("warning: Failed to read meshdata: attribCount '%s'.", _path.c_str());
- goto FAILED;
- }
- meshData = new (std::nothrow) MeshData();
- meshData->attribCount = attribSize;
- meshData->attribs.resize(meshData->attribCount);
- for (ssize_t j = 0; j < meshData->attribCount; ++j)
- {
- std::string attribute="";
- unsigned int vSize;
- if (_binaryReader.read(&vSize, 4, 1) != 1)
- {
- CCLOG("warning: Failed to read meshdata: usage or size '%s'.", _path.c_str());
- goto FAILED;
- }
- std::string type = _binaryReader.readString();
- attribute=_binaryReader.readString();
- meshData->attribs[j].size = vSize;
- meshData->attribs[j].attribSizeBytes = meshData->attribs[j].size * 4;
- meshData->attribs[j].type = parseGLType(type);
- meshData->attribs[j].vertexAttrib = parseGLProgramAttribute(attribute);
- }
- unsigned int vertexSizeInFloat = 0;
-
- if (_binaryReader.read(&vertexSizeInFloat, 4, 1) != 1 || vertexSizeInFloat == 0)
- {
- CCLOG("warning: Failed to read meshdata: vertexSizeInFloat '%s'.", _path.c_str());
- goto FAILED;
- }
- meshData->vertex.resize(vertexSizeInFloat);
- if (_binaryReader.read(&meshData->vertex[0], 4, vertexSizeInFloat) != vertexSizeInFloat)
- {
- CCLOG("warning: Failed to read meshdata: vertex element '%s'.", _path.c_str());
- goto FAILED;
- }
-
- unsigned int meshPartCount = 1;
- _binaryReader.read(&meshPartCount, 4, 1);
- for (unsigned int k = 0; k < meshPartCount; ++k)
- {
- std::vector<unsigned short> indexArray;
- std:: string meshPartid = _binaryReader.readString();
- meshData->subMeshIds.push_back(meshPartid);
- unsigned int nIndexCount;
- if (_binaryReader.read(&nIndexCount, 4, 1) != 1)
- {
- CCLOG("warning: Failed to read meshdata: nIndexCount '%s'.", _path.c_str());
- goto FAILED;
- }
- indexArray.resize(nIndexCount);
- if (_binaryReader.read(&indexArray[0], 2, nIndexCount) != nIndexCount)
- {
- CCLOG("warning: Failed to read meshdata: indices '%s'.", _path.c_str());
- goto FAILED;
- }
- meshData->subMeshIndices.push_back(indexArray);
- meshData->numIndex = (int)meshData->subMeshIndices.size();
-
- if (_version != "0.3" && _version != "0.4" && _version != "0.5")
- {
-
- float aabb[6];
- if (_binaryReader.read(aabb, 4, 6) != 6)
- {
- CCLOG("warning: Failed to read meshdata: aabb '%s'.", _path.c_str());
- goto FAILED;
- }
- meshData->subMeshAABB.push_back(AABB(Vec3(aabb[0], aabb[1], aabb[2]), Vec3(aabb[3], aabb[4], aabb[5])));
- }
- else
- {
- meshData->subMeshAABB.push_back(calculateAABB(meshData->vertex, meshData->getPerVertexSize(), indexArray));
- }
- }
- meshdatas.meshDatas.push_back(meshData);
- }
- return true;
-
- FAILED:
- {
- CC_SAFE_DELETE(meshData);
- for (auto& meshdata : meshdatas.meshDatas) {
- delete meshdata;
- }
- meshdatas.meshDatas.clear();
- return false;
- }
- }
- bool Bundle3D::loadMeshDatasBinary_0_1(MeshDatas& meshdatas)
- {
- if (!seekToFirstType(BUNDLE_TYPE_MESH))
- return false;
- meshdatas.resetData();
- MeshData* meshdata = new (std::nothrow) MeshData();
-
- unsigned int attribSize=0;
- if (_binaryReader.read(&attribSize, 4, 1) != 1 || attribSize < 1)
- {
- CCLOG("warning: Failed to read meshdata: attribCount '%s'.", _path.c_str());
- CC_SAFE_DELETE(meshdata);
- return false;
- }
- enum
- {
- VERTEX_ATTRIB_POSITION,
- VERTEX_ATTRIB_COLOR,
- VERTEX_ATTRIB_TEX_COORD,
- VERTEX_ATTRIB_NORMAL,
- VERTEX_ATTRIB_BLEND_WEIGHT,
- VERTEX_ATTRIB_BLEND_INDEX,
- VERTEX_ATTRIB_MAX,
-
- VERTEX_ATTRIB_TEX_COORDS = VERTEX_ATTRIB_TEX_COORD,
- };
- for (unsigned int i = 0; i < attribSize; ++i)
- {
- unsigned int vUsage, vSize;
- if (_binaryReader.read(&vUsage, 4, 1) != 1 || _binaryReader.read(&vSize, 4, 1) != 1)
- {
- CCLOG("warning: Failed to read meshdata: usage or size '%s'.", _path.c_str());
- CC_SAFE_DELETE(meshdata);
- return false;
- }
- MeshVertexAttrib meshVertexAttribute;
- meshVertexAttribute.size = vSize;
- meshVertexAttribute.attribSizeBytes = vSize * 4;
- meshVertexAttribute.type = GL_FLOAT;
- if(vUsage == VERTEX_ATTRIB_NORMAL)
- {
- vUsage= GLProgram::VERTEX_ATTRIB_NORMAL;
- }
- else if(vUsage == VERTEX_ATTRIB_BLEND_WEIGHT)
- {
- vUsage= GLProgram::VERTEX_ATTRIB_BLEND_WEIGHT;
- }
- else if(vUsage == VERTEX_ATTRIB_BLEND_INDEX)
- {
- vUsage= GLProgram::VERTEX_ATTRIB_BLEND_INDEX;
- }
- else if(vUsage == VERTEX_ATTRIB_POSITION)
- {
- vUsage= GLProgram::VERTEX_ATTRIB_POSITION;
- }
- else if(vUsage == VERTEX_ATTRIB_TEX_COORD)
- {
- vUsage= GLProgram::VERTEX_ATTRIB_TEX_COORD;
- }
- meshVertexAttribute.vertexAttrib = vUsage;
- meshdata->attribs.push_back(meshVertexAttribute);
- }
-
- if (_binaryReader.read(&meshdata->vertexSizeInFloat, 4, 1) != 1 || meshdata->vertexSizeInFloat == 0)
- {
- CCLOG("warning: Failed to read meshdata: vertexSizeInFloat '%s'.", _path.c_str());
- CC_SAFE_DELETE(meshdata);
- return false;
- }
- meshdata->vertex.resize(meshdata->vertexSizeInFloat);
- if (_binaryReader.read(&meshdata->vertex[0], 4, meshdata->vertexSizeInFloat) != meshdata->vertexSizeInFloat)
- {
- CCLOG("warning: Failed to read meshdata: vertex element '%s'.", _path.c_str());
- CC_SAFE_DELETE(meshdata);
- return false;
- }
-
- unsigned int meshPartCount = 1;
- for (unsigned int i = 0; i < meshPartCount; ++i)
- {
- unsigned int nIndexCount;
- if (_binaryReader.read(&nIndexCount, 4, 1) != 1)
- {
- CCLOG("warning: Failed to read meshdata: nIndexCount '%s'.", _path.c_str());
- CC_SAFE_DELETE(meshdata);
- return false;
- }
- std::vector<unsigned short> indices;
- indices.resize(nIndexCount);
- if (_binaryReader.read(&indices[0], 2, nIndexCount) != nIndexCount)
- {
- CCLOG("warning: Failed to read meshdata: indices '%s'.", _path.c_str());
- CC_SAFE_DELETE(meshdata);
- return false;
- }
- meshdata->subMeshIndices.push_back(indices);
- meshdata->subMeshAABB.push_back(calculateAABB(meshdata->vertex, meshdata->getPerVertexSize(), indices));
- }
- meshdatas.meshDatas.push_back(meshdata);
- return true;
- }
- bool Bundle3D::loadMeshDatasBinary_0_2(MeshDatas& meshdatas)
- {
- if (!seekToFirstType(BUNDLE_TYPE_MESH))
- return false;
- meshdatas.resetData();
- MeshData* meshdata = new (std::nothrow) MeshData();
-
- unsigned int attribSize=0;
- if (_binaryReader.read(&attribSize, 4, 1) != 1 || attribSize < 1)
- {
- CCLOG("warning: Failed to read meshdata: attribCount '%s'.", _path.c_str());
- CC_SAFE_DELETE(meshdata);
- return false;
- }
- enum
- {
- VERTEX_ATTRIB_POSITION,
- VERTEX_ATTRIB_COLOR,
- VERTEX_ATTRIB_TEX_COORD,
- VERTEX_ATTRIB_NORMAL,
- VERTEX_ATTRIB_BLEND_WEIGHT,
- VERTEX_ATTRIB_BLEND_INDEX,
- VERTEX_ATTRIB_MAX,
-
- VERTEX_ATTRIB_TEX_COORDS = VERTEX_ATTRIB_TEX_COORD,
- };
- for (unsigned int i = 0; i < attribSize; ++i)
- {
- unsigned int vUsage, vSize;
- if (_binaryReader.read(&vUsage, 4, 1) != 1 || _binaryReader.read(&vSize, 4, 1) != 1)
- {
- CCLOG("warning: Failed to read meshdata: usage or size '%s'.", _path.c_str());
- CC_SAFE_DELETE(meshdata);
- return false;
- }
- MeshVertexAttrib meshVertexAttribute;
- meshVertexAttribute.size = vSize;
- meshVertexAttribute.attribSizeBytes = vSize * 4;
- meshVertexAttribute.type = GL_FLOAT;
- if(vUsage == VERTEX_ATTRIB_NORMAL)
- {
- vUsage= GLProgram::VERTEX_ATTRIB_NORMAL;
- }
- else if(vUsage == VERTEX_ATTRIB_BLEND_WEIGHT)
- {
- vUsage= GLProgram::VERTEX_ATTRIB_BLEND_WEIGHT;
- }
- else if(vUsage == VERTEX_ATTRIB_BLEND_INDEX)
- {
- vUsage= GLProgram::VERTEX_ATTRIB_BLEND_INDEX;
- }
- else if(vUsage == VERTEX_ATTRIB_POSITION)
- {
- vUsage= GLProgram::VERTEX_ATTRIB_POSITION;
- }
- else if(vUsage == VERTEX_ATTRIB_TEX_COORD)
- {
- vUsage= GLProgram::VERTEX_ATTRIB_TEX_COORD;
- }
- meshVertexAttribute.vertexAttrib = vUsage;
- meshdata->attribs.push_back(meshVertexAttribute);
- }
-
- if (_binaryReader.read(&meshdata->vertexSizeInFloat, 4, 1) != 1 || meshdata->vertexSizeInFloat == 0)
- {
- CCLOG("warning: Failed to read meshdata: vertexSizeInFloat '%s'.", _path.c_str());
- CC_SAFE_DELETE(meshdata);
- return false;
- }
- meshdata->vertex.resize(meshdata->vertexSizeInFloat);
- if (_binaryReader.read(&meshdata->vertex[0], 4, meshdata->vertexSizeInFloat) != meshdata->vertexSizeInFloat)
- {
- CCLOG("warning: Failed to read meshdata: vertex element '%s'.", _path.c_str());
- CC_SAFE_DELETE(meshdata);
- return false;
- }
-
- unsigned int submeshCount;
- if (_binaryReader.read(&submeshCount, 4, 1) != 1)
- {
- CCLOG("warning: Failed to read meshdata: submeshCount '%s'.", _path.c_str());
- CC_SAFE_DELETE(meshdata);
- return false;
- }
- for (unsigned int i = 0; i < submeshCount; ++i)
- {
- unsigned int nIndexCount;
- if (_binaryReader.read(&nIndexCount, 4, 1) != 1)
- {
- CCLOG("warning: Failed to read meshdata: nIndexCount '%s'.", _path.c_str());
- CC_SAFE_DELETE(meshdata);
- return false;
- }
- std::vector<unsigned short> indices;
- indices.resize(nIndexCount);
- if (_binaryReader.read(&indices[0], 2, nIndexCount) != nIndexCount)
- {
- CCLOG("warning: Failed to read meshdata: indices '%s'.", _path.c_str());
- CC_SAFE_DELETE(meshdata);
- return false;
- }
- meshdata->subMeshIndices.push_back(indices);
- meshdata->subMeshAABB.push_back(calculateAABB(meshdata->vertex, meshdata->getPerVertexSize(), indices));
- }
- meshdatas.meshDatas.push_back(meshdata);
-
- return true;
- }
- bool Bundle3D::loadMeshDatasJson(MeshDatas& meshdatas)
- {
- const rapidjson::Value& mesh_data_array = _jsonReader[MESHES];
- for (rapidjson::SizeType index = 0, mesh_data_array_size = mesh_data_array.Size(); index < mesh_data_array_size; ++index)
- {
- MeshData* meshData = new (std::nothrow) MeshData();
- const rapidjson::Value& mesh_data = mesh_data_array[index];
-
- const rapidjson::Value& mesh_vertex_attribute = mesh_data[ATTRIBUTES];
- MeshVertexAttrib tempAttrib;
- meshData->attribCount=mesh_vertex_attribute.Size();
- meshData->attribs.resize(meshData->attribCount);
- for (rapidjson::SizeType i = 0, mesh_vertex_attribute_size = mesh_vertex_attribute.Size(); i < mesh_vertex_attribute_size; ++i)
- {
- const rapidjson::Value& mesh_vertex_attribute_val = mesh_vertex_attribute[i];
- int size = mesh_vertex_attribute_val[ATTRIBUTESIZE].GetInt();
- std::string type = mesh_vertex_attribute_val[TYPE].GetString();
- std::string attribute = mesh_vertex_attribute_val[ATTRIBUTE].GetString();
- tempAttrib.size = size;
- tempAttrib.attribSizeBytes = sizeof(float) * size;
- tempAttrib.type = parseGLType(type);
- tempAttrib.vertexAttrib = parseGLProgramAttribute(attribute);
- meshData->attribs[i]=tempAttrib;
- }
-
-
- const rapidjson::Value& mesh_data_vertex_array = mesh_data[VERTICES];
- auto mesh_data_vertex_array_size = mesh_data_vertex_array.Size();
- meshData->vertexSizeInFloat = mesh_data_vertex_array_size;
- for (rapidjson::SizeType i = 0; i < mesh_data_vertex_array_size; ++i)
- {
- meshData->vertex.push_back(mesh_data_vertex_array[i].GetDouble());
- }
-
-
- const rapidjson::Value& mesh_part_array = mesh_data[PARTS];
- for (rapidjson::SizeType i = 0, mesh_part_array_size = mesh_part_array.Size(); i < mesh_part_array_size; ++i)
- {
- std::vector<unsigned short> indexArray;
- const rapidjson::Value& mesh_part = mesh_part_array[i];
- meshData->subMeshIds.push_back(mesh_part[ID].GetString());
-
- const rapidjson::Value& indices_val_array = mesh_part[INDICES];
- for (rapidjson::SizeType j = 0, indices_val_array_size = indices_val_array.Size(); j < indices_val_array_size; ++j)
- indexArray.push_back((unsigned short)indices_val_array[j].GetUint());
- meshData->subMeshIndices.push_back(indexArray);
- meshData->numIndex = (int)meshData->subMeshIndices.size();
- if(mesh_data.HasMember(AABBS))
- {
- const rapidjson::Value& mesh_part_aabb = mesh_part[AABBS];
- if (mesh_part.HasMember(AABBS) && mesh_part_aabb.Size() == 6)
- {
- Vec3 min(mesh_part_aabb[(rapidjson::SizeType)0].GetDouble(),
- mesh_part_aabb[(rapidjson::SizeType)1].GetDouble(), mesh_part_aabb[(rapidjson::SizeType)2].GetDouble());
- Vec3 max(mesh_part_aabb[(rapidjson::SizeType)3].GetDouble(),
- mesh_part_aabb[(rapidjson::SizeType)4].GetDouble(), mesh_part_aabb[(rapidjson::SizeType)5].GetDouble());
- meshData->subMeshAABB.push_back(AABB(min, max));
- }
- else
- {
- meshData->subMeshAABB.push_back(calculateAABB(meshData->vertex, meshData->getPerVertexSize(), indexArray));
- }
- }
- else
- {
- meshData->subMeshAABB.push_back(calculateAABB(meshData->vertex, meshData->getPerVertexSize(), indexArray));
- }
-
- }
- meshdatas.meshDatas.push_back(meshData);
- }
- return true;
- }
- bool Bundle3D::loadNodes(NodeDatas& nodedatas)
- {
- if (_version == "0.1" || _version == "1.2" || _version == "0.2")
- {
- SkinData skinData;
- if (!loadSkinData("", &skinData))
- {
- auto node= new (std::nothrow) NodeData();
- auto modelnode = new (std::nothrow) ModelData();
- modelnode->materialId = "";
- modelnode->subMeshId = "";
- node->modelNodeDatas.push_back(modelnode);
- nodedatas.nodes.push_back(node);
- return true;
- }
-
- auto nodeDatas = new (std::nothrow) NodeData*[skinData.skinBoneNames.size() + skinData.nodeBoneNames.size()];
- int index = 0;
- size_t i;
- auto skinBoneSize = skinData.skinBoneNames.size();
- auto nodeBoneSize = skinData.nodeBoneNames.size();
- for (i = 0; i < skinBoneSize; ++i)
- {
- nodeDatas[index] = new (std::nothrow) NodeData();
- nodeDatas[index]->id = skinData.skinBoneNames[i];
- nodeDatas[index]->transform = skinData.skinBoneOriginMatrices[i];
- ++index;
- }
- for (i = 0; i < nodeBoneSize; ++i)
- {
- nodeDatas[index] = new (std::nothrow) NodeData();
- nodeDatas[index]->id = skinData.nodeBoneNames[i];
- nodeDatas[index]->transform = skinData.nodeBoneOriginMatrices[i];
- ++index;
- }
- for (const auto& it : skinData.boneChild)
- {
- const auto& children = it.second;
- auto parent = nodeDatas[it.first];
- for (const auto& child : children)
- {
- parent->children.push_back(nodeDatas[child]);
- }
- }
- nodedatas.skeleton.push_back(nodeDatas[skinData.rootBoneIndex]);
- auto node= new (std::nothrow) NodeData();
- auto modelnode = new (std::nothrow) ModelData();
- modelnode->materialId = "";
- modelnode->subMeshId = "";
- modelnode->bones = skinData.skinBoneNames;
- modelnode->invBindPose = skinData.inverseBindPoseMatrices;
- node->modelNodeDatas.push_back(modelnode);
- nodedatas.nodes.push_back(node);
- delete[] nodeDatas;
- }
- else
- {
- if (_isBinary)
- {
- loadNodesBinary(nodedatas);
- }
- else
- {
- loadNodesJson(nodedatas);
- }
- }
- return true;
- }
- bool Bundle3D::loadMaterials(MaterialDatas& materialdatas)
- {
- materialdatas.resetData();
- if (_isBinary)
- {
- if (_version == "0.1")
- {
- return loadMaterialsBinary_0_1(materialdatas);
- }
- else if (_version == "0.2")
- {
- return loadMaterialsBinary_0_2(materialdatas);
- }
- else
- {
- return loadMaterialsBinary(materialdatas);
- }
- }
- else
- {
- if (_version == "1.2")
- {
- return loadMaterialDataJson_0_1(materialdatas);
- }
- else if (_version == "0.2")
- {
- return loadMaterialDataJson_0_2(materialdatas);
- }
- else
- {
- return loadMaterialsJson(materialdatas);
- }
- }
- return true;
- }
- bool Bundle3D::loadMaterialsBinary(MaterialDatas& materialdatas)
- {
- if (!seekToFirstType(BUNDLE_TYPE_MATERIAL))
- return false;
- unsigned int materialnum = 1;
- _binaryReader.read(&materialnum, 4, 1);
- for (unsigned int i = 0; i < materialnum; ++i)
- {
- NMaterialData materialData;
- materialData.id = _binaryReader.readString();
-
-
- float data[14];
- _binaryReader.read(&data,sizeof(float), 14);
-
- unsigned int textureNum = 1;
- _binaryReader.read(&textureNum, 4, 1);
- for (unsigned int j = 0; j < textureNum; ++j)
- {
- NTextureData textureData;
- textureData.id = _binaryReader.readString();
- if (textureData.id.empty())
- {
- CCLOG("warning: Failed to read Materialdata: texturePath is empty '%s'.", textureData.id.c_str());
- return false;
- }
- std::string texturePath = _binaryReader.readString();
- if (texturePath.empty())
- {
- CCLOG("warning: Failed to read Materialdata: texturePath is empty '%s'.", _path.c_str());
- return false;
- }
- textureData.filename = texturePath.empty() ? texturePath : _modelPath + texturePath;
- float uvdata[4];
- _binaryReader.read(&uvdata,sizeof(float), 4);
- textureData.type = parseGLTextureType(_binaryReader.readString());
- textureData.wrapS= parseGLType(_binaryReader.readString());
- textureData.wrapT= parseGLType(_binaryReader.readString());
- materialData.textures.push_back(textureData);
- }
- materialdatas.materials.push_back(materialData);
- }
- return true;
- }
- bool Bundle3D::loadMaterialsBinary_0_1(MaterialDatas& materialdatas)
- {
- if (!seekToFirstType(BUNDLE_TYPE_MATERIAL))
- return false;
- NMaterialData materialData;
- std::string texturePath = _binaryReader.readString();
- if (texturePath.empty())
- {
- CCLOG("warning: Failed to read Materialdata: texturePath is empty '%s'.", _path.c_str());
- return false;
- }
- NTextureData textureData;
- textureData.filename = texturePath.empty() ? texturePath : _modelPath + texturePath;
- textureData.type= NTextureData::Usage::Diffuse;
- textureData.id="";
- materialData.textures.push_back(textureData);
- materialdatas.materials.push_back(materialData);
- return true;
- }
- bool Bundle3D::loadMaterialsBinary_0_2(MaterialDatas& materialdatas)
- {
- if (!seekToFirstType(BUNDLE_TYPE_MATERIAL))
- return false;
- unsigned int materialnum = 1;
- _binaryReader.read(&materialnum, 4, 1);
- for (unsigned int i = 0; i < materialnum; ++i)
- {
- NMaterialData materialData;
- std::string texturePath = _binaryReader.readString();
- if (texturePath.empty())
- {
- CCLOG("warning: Failed to read Materialdata: texturePath is empty '%s'.", _path.c_str());
- return true;
- }
- NTextureData textureData;
- textureData.filename = texturePath.empty() ? texturePath : _modelPath + texturePath;
- textureData.type= NTextureData::Usage::Diffuse;
- textureData.id="";
- materialData.textures.push_back(textureData);
- materialdatas.materials.push_back(materialData);
- }
- return true;
- }
- bool loadMeshDataJson(MeshData* ){
- return true;
- }
- bool loadMeshDataJson_0_1(MeshData* )
- {
- return true;
- }
- bool loadMeshDataJson_0_2(MeshData* )
- {
- return true;
- }
- bool Bundle3D::loadMaterialsJson(MaterialDatas& materialdatas)
- {
- if (!_jsonReader.HasMember(MATERIALS))
- return false;
- const rapidjson::Value& material_array = _jsonReader[MATERIALS];
- for (rapidjson::SizeType i = 0; i < material_array.Size(); ++i)
- {
- NMaterialData materialData;
- const rapidjson::Value& material_val = material_array[i];
- materialData.id = material_val[ID].GetString();
- if (material_val.HasMember(TEXTURES))
- {
- const rapidjson::Value& texture_array = material_val[TEXTURES];
- for (rapidjson::SizeType j = 0; j < texture_array.Size(); ++j)
- {
- NTextureData textureData;
- const rapidjson::Value& texture_val = texture_array[j];
- std::string filename = texture_val[FILENAME].GetString();
- textureData.filename = filename.empty() ? filename : _modelPath + filename;
- textureData.type = parseGLTextureType(texture_val["type"].GetString());
- textureData.wrapS = parseGLType(texture_val["wrapModeU"].GetString());
- textureData.wrapT = parseGLType(texture_val["wrapModeV"].GetString());
- materialData.textures.push_back(textureData);
- }
- }
- materialdatas.materials.push_back(materialData);
- }
- return true;
- }
- bool Bundle3D::loadJson(const std::string& path)
- {
- clear();
- _jsonBuffer = FileUtils::getInstance()->getStringFromFile(path);
- if (_jsonReader.ParseInsitu<0>((char*)_jsonBuffer.c_str()).HasParseError())
- {
- clear();
- CCLOG("Parse json failed in Bundle3D::loadJson function");
- return false;
- }
- const rapidjson::Value& mash_data_array = _jsonReader[VERSION];
- if (mash_data_array.IsArray())
- _version = "1.2";
- else
- _version = mash_data_array.GetString();
-
- return true;
- }
- bool Bundle3D::loadBinary(const std::string& path)
- {
- clear();
-
-
- _binaryBuffer.clear();
- _binaryBuffer = FileUtils::getInstance()->getDataFromFile(path);
- if (_binaryBuffer.isNull())
- {
- clear();
- CCLOG("warning: Failed to read file: %s", path.c_str());
- return false;
- }
-
-
- _binaryReader.init( (char*)_binaryBuffer.getBytes(), _binaryBuffer.getSize() );
-
-
- char identifier[] = { 'C', '3', 'B', '\0'};
- char sig[4];
- if (_binaryReader.read(sig, 1, 4) != 4 || memcmp(sig, identifier, 4) != 0)
- {
- clear();
- CCLOG("warning: Invalid identifier: %s", path.c_str());
- return false;
- }
-
-
- unsigned char ver[2];
- if (_binaryReader.read(ver, 1, 2)!= 2){
- CCLOG("warning: Failed to read version:");
- return false;
- }
-
- char version[20] = {0};
- sprintf(version, "%d.%d", ver[0], ver[1]);
- _version = version;
-
-
- if (_binaryReader.read(&_referenceCount, 4, 1) != 1)
- {
- clear();
- CCLOG("warning: Failed to read ref table size '%s'.", path.c_str());
- return false;
- }
-
-
- CC_SAFE_DELETE_ARRAY(_references);
- _references = new (std::nothrow) Reference[_referenceCount];
- for (unsigned int i = 0; i < _referenceCount; ++i)
- {
- if ((_references[i].id = _binaryReader.readString()).empty() ||
- _binaryReader.read(&_references[i].type, 4, 1) != 1 ||
- _binaryReader.read(&_references[i].offset, 4, 1) != 1)
- {
- clear();
- CCLOG("warning: Failed to read ref number %u for bundle '%s'.", i, path.c_str());
- CC_SAFE_DELETE_ARRAY(_references);
- return false;
- }
- }
-
- return true;
- }
- bool Bundle3D::loadMeshDataJson_0_1(MeshDatas& meshdatas)
- {
- const rapidjson::Value& mesh_data_array = _jsonReader[MESH];
- MeshData* meshdata= new (std::nothrow) MeshData();
- const rapidjson::Value& mesh_data_val = mesh_data_array[(rapidjson::SizeType)0];
- const rapidjson::Value& mesh_data_body_array = mesh_data_val[DEFAULTPART];
- const rapidjson::Value& mesh_data_body_array_0 = mesh_data_body_array[(rapidjson::SizeType)0];
-
- const rapidjson::Value& mesh_vertex_attribute = mesh_data_val[ATTRIBUTES];
- meshdata->attribCount = mesh_vertex_attribute.Size();
- meshdata->attribs.resize(meshdata->attribCount);
- for (rapidjson::SizeType i = 0; i < mesh_vertex_attribute.Size(); ++i)
- {
- const rapidjson::Value& mesh_vertex_attribute_val = mesh_vertex_attribute[i];
- meshdata->attribs[i].size = mesh_vertex_attribute_val[ATTRIBUTESIZE].GetUint();
- meshdata->attribs[i].attribSizeBytes = meshdata->attribs[i].size * 4;
- meshdata->attribs[i].type = parseGLType(mesh_vertex_attribute_val[TYPE].GetString());
- meshdata->attribs[i].vertexAttrib = parseGLProgramAttribute(mesh_vertex_attribute_val[ATTRIBUTE].GetString());
- }
-
- meshdata->vertexSizeInFloat = mesh_data_body_array_0[VERTEXSIZE].GetInt();
- meshdata->vertex.resize(meshdata->vertexSizeInFloat);
- const rapidjson::Value& mesh_data_body_vertices = mesh_data_body_array_0[VERTICES];
- for (rapidjson::SizeType i = 0; i < mesh_data_body_vertices.Size(); ++i)
- meshdata->vertex[i] = mesh_data_body_vertices[i].GetDouble();
-
- unsigned int indexnum = mesh_data_body_array_0[INDEXNUM].GetUint();
-
- std::vector<unsigned short> indices;
- indices.resize(indexnum);
- const rapidjson::Value& indices_val_array = mesh_data_body_array_0[INDICES];
- for (rapidjson::SizeType i = 0; i < indices_val_array.Size(); ++i)
- indices[i] = (unsigned short)indices_val_array[i].GetUint();
- meshdata->subMeshIndices.push_back(indices);
- meshdata->subMeshAABB.push_back(calculateAABB(meshdata->vertex, meshdata->getPerVertexSize(), indices));
- meshdatas.meshDatas.push_back(meshdata);
- return true;
- }
- bool Bundle3D::loadMeshDataJson_0_2(MeshDatas& meshdatas)
- {
- MeshData* meshdata= new (std::nothrow) MeshData();
- const rapidjson::Value& mesh_array = _jsonReader[MESH];
- const rapidjson::Value& mesh_array_0 = mesh_array[(rapidjson::SizeType)0];
-
- const rapidjson::Value& mesh_vertex_attribute = mesh_array_0[ATTRIBUTES];
- meshdata->attribCount = mesh_vertex_attribute.Size();
- meshdata->attribs.resize(meshdata->attribCount);
- for (rapidjson::SizeType i = 0; i < mesh_vertex_attribute.Size(); ++i)
- {
- const rapidjson::Value& mesh_vertex_attribute_val = mesh_vertex_attribute[i];
- meshdata->attribs[i].size = mesh_vertex_attribute_val[ATTRIBUTESIZE].GetUint();
- meshdata->attribs[i].attribSizeBytes = meshdata->attribs[i].size * 4;
- meshdata->attribs[i].type = parseGLType(mesh_vertex_attribute_val[TYPE].GetString());
- meshdata->attribs[i].vertexAttrib = parseGLProgramAttribute(mesh_vertex_attribute_val[ATTRIBUTE].GetString());
- }
-
- const rapidjson::Value& mesh_data_vertex = mesh_array_0[VERTEX];
- const rapidjson::Value& mesh_data_vertex_0 = mesh_data_vertex[(rapidjson::SizeType)0];
- meshdata->vertexSizeInFloat = mesh_data_vertex_0[VERTEXSIZE].GetInt();
- meshdata->vertex.resize(meshdata->vertexSizeInFloat);
- const rapidjson::Value& mesh_data_body_vertices = mesh_data_vertex_0[VERTICES];
- for (rapidjson::SizeType i = 0; i < mesh_data_body_vertices.Size(); ++i)
- meshdata->vertex[i] = mesh_data_body_vertices[i].GetDouble();
-
- const rapidjson::Value& mesh_submesh_array = mesh_array_0[SUBMESH];
- for (rapidjson::SizeType i = 0; i < mesh_submesh_array.Size(); ++i)
- {
- const rapidjson::Value& mesh_submesh_val = mesh_submesh_array[i];
-
-
- unsigned int indexnum = mesh_submesh_val[INDEXNUM].GetUint();
-
- std::vector<unsigned short> indices;
- indices.resize(indexnum);
- const rapidjson::Value& indices_val_array = mesh_submesh_val[INDICES];
- for (rapidjson::SizeType j = 0; j < indices_val_array.Size(); ++j)
- indices[j] = (unsigned short)indices_val_array[j].GetUint();
- meshdata->subMeshIndices.push_back(indices);
- meshdata->subMeshAABB.push_back(calculateAABB(meshdata->vertex, meshdata->getPerVertexSize(), indices));
- }
- meshdatas.meshDatas.push_back(meshdata);
- return true;
- }
- bool Bundle3D::loadSkinDataJson(SkinData* skindata)
- {
- if (!_jsonReader.HasMember(SKIN )) return false;
- const rapidjson::Value& skin_data_array = _jsonReader[SKIN ];
- CCASSERT(skin_data_array.IsArray(), "skin data is not an array");
- const rapidjson::Value& skin_data_array_val_0 = skin_data_array[(rapidjson::SizeType)0];
- if (!skin_data_array_val_0.HasMember(BONES))
- return false;
- const rapidjson::Value& skin_data_bones = skin_data_array_val_0[BONES];
- for (rapidjson::SizeType i = 0; i < skin_data_bones.Size(); ++i)
- {
- const rapidjson::Value& skin_data_bone = skin_data_bones[i];
- std::string name = skin_data_bone[NODE].GetString();
- skindata->addSkinBoneNames(name);
- Mat4 mat_bind_pos;
- const rapidjson::Value& bind_pos = skin_data_bone[BINDSHAPE];
- for (rapidjson::SizeType j = 0; j < bind_pos.Size(); ++j)
- {
- mat_bind_pos.m[j] = bind_pos[j].GetDouble();
- }
- skindata->inverseBindPoseMatrices.push_back(mat_bind_pos);
- }
-
- const rapidjson::Value& skin_data_1 = skin_data_array[1];
-
- skindata->skinBoneOriginMatrices.resize(skindata->skinBoneNames.size());
- getChildMap(skindata->boneChild, skindata, skin_data_1);
- return true;
- }
- bool Bundle3D::loadSkinDataBinary(SkinData* skindata)
- {
- if (!seekToFirstType(BUNDLE_TYPE_MESHSKIN))
- return false;
-
- std::string boneName = _binaryReader.readString();
-
-
- float bindShape[16];
- if (!_binaryReader.readMatrix(bindShape))
- {
- CCLOG("warning: Failed to read SkinData: bindShape matrix '%s'.", _path.c_str());
- return false;
- }
-
-
- unsigned int boneNum;
- if (!_binaryReader.read(&boneNum))
- {
- CCLOG("warning: Failed to read SkinData: boneNum '%s'.", _path.c_str());
- return false;
- }
-
-
- if (boneNum == 0)
- return false;
-
-
- float bindpos[16];
- for (unsigned int i = 0; i < boneNum; ++i)
- {
- std::string skinBoneName = _binaryReader.readString();
- skindata->skinBoneNames.push_back(skinBoneName);
- if (!_binaryReader.readMatrix(bindpos))
- {
- CCLOG("warning: Failed to load SkinData: bindpos '%s'.", _path.c_str());
- return false;
- }
- skindata->inverseBindPoseMatrices.push_back(bindpos);
- }
-
- skindata->skinBoneOriginMatrices.resize(boneNum);
-
- boneName = _binaryReader.readString();
-
-
- _binaryReader.readMatrix(bindShape);
- int rootIndex = skindata->getSkinBoneNameIndex(boneName);
- if(rootIndex < 0)
- {
- skindata->addNodeBoneNames(boneName);
- rootIndex = skindata->getBoneNameIndex(boneName);
- skindata->nodeBoneOriginMatrices.push_back(bindShape);
- }
- else
- {
- skindata->skinBoneOriginMatrices[rootIndex] = bindShape;
- }
-
-
- skindata->rootBoneIndex = rootIndex;
-
-
- float transform[16];
- unsigned int linkNum;
- _binaryReader.read(&linkNum);
- for (unsigned int i = 0; i < linkNum; ++i)
- {
- std::string id = _binaryReader.readString();
- int index = skindata->getSkinBoneNameIndex(id);
-
-
- std::string parentid = _binaryReader.readString();
-
- if (!_binaryReader.readMatrix(transform))
- {
- CCLOG("warning: Failed to load SkinData: transform '%s'.", _path.c_str());
- return false;
- }
-
- if(index < 0)
- {
- skindata->addNodeBoneNames(id);
- index = skindata->getBoneNameIndex(id);
- skindata->nodeBoneOriginMatrices.push_back(transform);
- }
- else
- {
- skindata->skinBoneOriginMatrices[index] = transform;
- }
-
- int parentIndex = skindata->getSkinBoneNameIndex(parentid);
- if(parentIndex < 0)
- {
- skindata->addNodeBoneNames(parentid);
- parentIndex = skindata->getBoneNameIndex(parentid);
- }
-
- skindata->boneChild[parentIndex].push_back(index);
-
- }
-
- return true;
- }
- bool Bundle3D::loadMaterialDataJson_0_1(MaterialDatas& materialdatas)
- {
- if (!_jsonReader.HasMember(MATERIAL))
- return false;
- NMaterialData materialData;
- const rapidjson::Value& material_data_array = _jsonReader[MATERIAL];
- if (material_data_array.Size() > 0)
- {
- const rapidjson::Value& material_data_array_0 = material_data_array[(rapidjson::SizeType)0];
- if (material_data_array_0.HasMember(BASE))
- {
- const rapidjson::Value& material_data_base_array = material_data_array_0[BASE];
- const rapidjson::Value& material_data_base_array_0 = material_data_base_array[(rapidjson::SizeType)0];
- NTextureData textureData;
-
- std::string filename = material_data_base_array_0[FILENAME].GetString();
- textureData.filename = filename.empty() ? filename : _modelPath + filename;
- textureData.type= NTextureData::Usage::Diffuse;
- textureData.id="";
- materialData.textures.push_back(textureData);
- materialdatas.materials.push_back(materialData);
- }
- }
-
- return true;
- }
- bool Bundle3D::loadMaterialDataJson_0_2(MaterialDatas& materialdatas)
- {
- if (!_jsonReader.HasMember(MATERIAL))
- return false;
- NMaterialData materialData;
- const rapidjson::Value& material_array = _jsonReader[MATERIAL];
- for (rapidjson::SizeType i = 0; i < material_array.Size(); ++i)
- {
- NTextureData textureData;
- const rapidjson::Value& material_val = material_array[i];
-
- std::string filename = material_val[TEXTURES].GetString();
- textureData.filename = filename.empty() ? filename : _modelPath + filename;
- textureData.type= NTextureData::Usage::Diffuse;
- textureData.id="";
- materialData.textures.push_back(textureData);
- }
- materialdatas.materials.push_back(materialData);
- return true;
- }
- bool loadMaterialDataJson(MaterialData* )
- {
- return true;
- }
- bool loadMaterialDataJson_0_1(MaterialData* ){
- return true;
- }
- bool loadMaterialDataJson_0_2(MaterialData* ){
- return true;
- }
- bool Bundle3D::loadAnimationDataJson(const std::string& id, Animation3DData* animationdata)
- {
- std::string anim = "";
- if (_version == "1.2" || _version == "0.2")
- anim = ANIMATION;
- else
- anim = ANIMATIONS;
- if (!_jsonReader.HasMember(anim.c_str())) return false;
- int the_index = -1;
- const rapidjson::Value& animation_data_array = _jsonReader[anim.c_str()];
- if (animation_data_array.Size()==0) return false;
- if(!id.empty())
- {
- for (rapidjson::SizeType i = 0; i < animation_data_array.Size(); ++i)
- {
- if(animation_data_array[i][ID].GetString() == id)
- {
- the_index = static_cast<int>(i);
- }
- }
- if(the_index < 0) return false;
- }else{
- the_index = 0;
- }
- const rapidjson::Value& animation_data_array_val_0 = animation_data_array[(rapidjson::SizeType)the_index];
- animationdata->_totalTime = animation_data_array_val_0[LENGTH].GetDouble();
- const rapidjson::Value& bones = animation_data_array_val_0[BONES];
- for (rapidjson::SizeType i = 0; i < bones.Size(); ++i)
- {
- const rapidjson::Value& bone = bones[i];
- std::string bone_name = bone[BONEID].GetString();
- if ( bone.HasMember(KEYFRAMES))
- {
- const rapidjson::Value& bone_keyframes = bone[KEYFRAMES];
- rapidjson::SizeType keyframe_size = bone_keyframes.Size();
- animationdata->_rotationKeys[bone_name].reserve(keyframe_size);
- animationdata->_scaleKeys[bone_name].reserve(keyframe_size);
- animationdata->_translationKeys[bone_name].reserve(keyframe_size);
-
- for (rapidjson::SizeType j = 0; j < keyframe_size; ++j)
- {
- const rapidjson::Value& bone_keyframe = bone_keyframes[j];
- if ( bone_keyframe.HasMember(TRANSLATION))
- {
- const rapidjson::Value& bone_keyframe_translation = bone_keyframe[TRANSLATION];
- float keytime = bone_keyframe[KEYTIME].GetDouble();
- Vec3 val(bone_keyframe_translation[(rapidjson::SizeType)0].GetDouble(), bone_keyframe_translation[1].GetDouble(), bone_keyframe_translation[2].GetDouble());
- animationdata->_translationKeys[bone_name].push_back(Animation3DData::Vec3Key(keytime,val));
- }
- if ( bone_keyframe.HasMember(ROTATION))
- {
- const rapidjson::Value& bone_keyframe_rotation = bone_keyframe[ROTATION];
- float keytime = bone_keyframe[KEYTIME].GetDouble();
- Quaternion val = Quaternion(bone_keyframe_rotation[(rapidjson::SizeType)0].GetDouble(),bone_keyframe_rotation[1].GetDouble(),bone_keyframe_rotation[2].GetDouble(),bone_keyframe_rotation[3].GetDouble());
- animationdata->_rotationKeys[bone_name].push_back(Animation3DData::QuatKey(keytime,val));
- }
- if ( bone_keyframe.HasMember(SCALE))
- {
- const rapidjson::Value& bone_keyframe_scale = bone_keyframe[SCALE];
- float keytime = bone_keyframe[KEYTIME].GetDouble();
- Vec3 val(bone_keyframe_scale[(rapidjson::SizeType)0].GetDouble(), bone_keyframe_scale[1].GetDouble(), bone_keyframe_scale[2].GetDouble());
- animationdata->_scaleKeys[bone_name].push_back(Animation3DData::Vec3Key(keytime,val));
- }
- }
- }
- }
- return true;
- }
- bool Bundle3D::loadAnimationDataBinary(const std::string& id, Animation3DData* animationdata)
- {
-
- if( _version == "0.1"|| _version == "0.2" || _version == "0.3"|| _version == "0.4")
- {
- if (!seekToFirstType(BUNDLE_TYPE_ANIMATIONS))
- return false;
- }
- else
- {
-
- std::string id_ = id;
- if(id != "") id_ = id + "animation";
-
- if (!seekToFirstType(BUNDLE_TYPE_ANIMATIONS, id_))
- return false;
- }
-
- unsigned int animNum = 1;
- if( _version == "0.3"|| _version == "0.4")
- {
- if (!_binaryReader.read(&animNum))
- {
- CCLOG("warning: Failed to read AnimationData: animNum '%s'.", _path.c_str());
- return false;
- }
- }
-
- bool has_found =false;
- for(unsigned int k = 0; k < animNum ; ++k )
- {
- animationdata->resetData();
- std::string animId = _binaryReader.readString();
- if (!_binaryReader.read(&animationdata->_totalTime))
- {
- CCLOG("warning: Failed to read AnimationData: totalTime '%s'.", _path.c_str());
- return false;
- }
- unsigned int nodeAnimationNum;
- if (!_binaryReader.read(&nodeAnimationNum))
- {
- CCLOG("warning: Failed to read AnimationData: animNum '%s'.", _path.c_str());
- return false;
- }
- for (unsigned int i = 0; i < nodeAnimationNum; ++i)
- {
- std::string boneName = _binaryReader.readString();
- unsigned int keyframeNum;
- if (!_binaryReader.read(&keyframeNum))
- {
- CCLOG("warning: Failed to read AnimationData: keyframeNum '%s'.", _path.c_str());
- return false;
- }
- animationdata->_rotationKeys[boneName].reserve(keyframeNum);
- animationdata->_scaleKeys[boneName].reserve(keyframeNum);
- animationdata->_translationKeys[boneName].reserve(keyframeNum);
- for (unsigned int j = 0; j < keyframeNum; ++j)
- {
- float keytime;
- if (!_binaryReader.read(&keytime))
- {
- CCLOG("warning: Failed to read AnimationData: keytime '%s'.", _path.c_str());
- return false;
- }
-
- unsigned char transformFlag(0);
- if (_version != "0.1" && _version != "0.2" && _version != "0.3")
- {
- if (!_binaryReader.read(&transformFlag))
- {
- CCLOG("warning: Failed to read AnimationData: transformFlag '%s'.", _path.c_str());
- return false;
- }
- }
-
- bool hasRotate = true;
- if (_version != "0.1" && _version != "0.2" && _version != "0.3")
- hasRotate = transformFlag & 0x01;
- if (hasRotate)
- {
- Quaternion rotate;
- if (_binaryReader.read(&rotate, 4, 4) != 4)
- {
- CCLOG("warning: Failed to read AnimationData: rotate '%s'.", _path.c_str());
- return false;
- }
- animationdata->_rotationKeys[boneName].push_back(Animation3DData::QuatKey(keytime, rotate));
- }
-
- bool hasScale = true;
- if (_version != "0.1" && _version != "0.2" && _version != "0.3")
- hasScale = (transformFlag >> 1) & 0x01;
- if (hasScale)
- {
- Vec3 scale;
- if (_binaryReader.read(&scale, 4, 3) != 3)
- {
- CCLOG("warning: Failed to read AnimationData: scale '%s'.", _path.c_str());
- return false;
- }
- animationdata->_scaleKeys[boneName].push_back(Animation3DData::Vec3Key(keytime, scale));
- }
-
- bool hasTranslation = true;
- if (_version != "0.1" && _version != "0.2" && _version != "0.3")
- hasTranslation = (transformFlag >> 2) & 0x01;
- if (hasTranslation)
- {
- Vec3 position;
- if (_binaryReader.read(&position, 4, 3) != 3)
- {
- CCLOG("warning: Failed to read AnimationData: position '%s'.", _path.c_str());
- return false;
- }
- animationdata->_translationKeys[boneName].push_back(Animation3DData::Vec3Key(keytime, position));
- }
- }
- }
- if( id == animId || id.empty())
- {
- has_found = true;
- break;
- }
- }
- if(!has_found)
- {
- animationdata->resetData();
- return false;
- }
- return true;
- }
- bool Bundle3D::loadNodesJson(NodeDatas& nodedatas)
- {
- if (!_jsonReader.HasMember(NODES)) return false;
- const rapidjson::Value& nodes = _jsonReader[NODES];
- if(!nodes.IsArray()) return false;
-
- for (rapidjson::SizeType i = 0; i < nodes.Size(); ++i)
- {
- const rapidjson::Value& jnode = nodes[i];
- std::string id = jnode[ID].GetString();
- NodeData* nodedata = parseNodesRecursivelyJson(jnode, nodes.Size() == 1);
- bool isSkeleton = jnode[SKELETON].GetBool();
- if (isSkeleton)
- nodedatas.skeleton.push_back(nodedata);
- else
- nodedatas.nodes.push_back(nodedata);
- }
- return true;
- }
- NodeData* Bundle3D::parseNodesRecursivelyJson(const rapidjson::Value& jvalue, bool singleSprite)
- {
- NodeData* nodedata = new (std::nothrow) NodeData();
-
- nodedata->id = jvalue[ID].GetString();
-
- Mat4 transform;
- const rapidjson::Value& jtransform = jvalue[TRANSFORM];
- for (rapidjson::SizeType j = 0; j < jtransform.Size(); ++j)
- {
- transform.m[j] = jtransform[j].GetDouble();
- }
- nodedata->transform = transform;
- bool isSkin = false;
-
-
- if (jvalue.HasMember(PARTS))
- {
- const rapidjson::Value& parts = jvalue[PARTS];
-
- for (rapidjson::SizeType i = 0; i < parts.Size(); ++i)
- {
- auto modelnodedata = new (std::nothrow) ModelData();
- const rapidjson::Value& part = parts[i];
- modelnodedata->subMeshId = part[MESHPARTID].GetString();
- modelnodedata->materialId = part[MATERIALID].GetString();
- if (modelnodedata->subMeshId == "" || modelnodedata->materialId == "")
- {
- CCLOG("warning: Node %s part is missing meshPartId or materialId", nodedata->id.c_str());
- CC_SAFE_DELETE(modelnodedata);
- CC_SAFE_DELETE(nodedata);
- return nullptr;
- }
- if (part.HasMember(BONES))
- {
- const rapidjson::Value& bones = part[BONES];
- for (rapidjson::SizeType j = 0; j < bones.Size(); ++j)
- {
- const rapidjson::Value& bone = bones[j];
-
- if (!bone.HasMember(NODE))
- {
- CCLOG("warning: Bone node ID missing");
- CC_SAFE_DELETE(modelnodedata);
- CC_SAFE_DELETE(nodedata);
- return nullptr;
- }
- modelnodedata->bones.push_back(bone[NODE].GetString());
- Mat4 invbindpos;
- const rapidjson::Value& jinvbindpos = bone[TRANSFORM];
- for (rapidjson::SizeType k = 0; k < jinvbindpos.Size(); ++k)
- {
- invbindpos.m[k] = jinvbindpos[k].GetDouble();
- }
-
- modelnodedata->invBindPose.push_back(invbindpos);
- }
-
- if (bones.Size() > 0)
- isSkin = true;
- }
- nodedata->modelNodeDatas.push_back(modelnodedata);
- }
- }
-
- if(_version == "0.1" || _version == "0.2" || _version == "0.3" || _version == "0.4" || _version == "0.5" || _version == "0.6")
- {
- if(isSkin || singleSprite)
- {
- nodedata->transform = Mat4::IDENTITY;
- }
- else
- {
- nodedata->transform = transform;
- }
- }
- else
- {
- nodedata->transform = transform;
- }
-
- if (jvalue.HasMember(CHILDREN))
- {
- const rapidjson::Value& children = jvalue[CHILDREN];
- for (rapidjson::SizeType i = 0; i < children.Size(); ++i)
- {
- const rapidjson::Value& child = children[i];
- NodeData* tempdata = parseNodesRecursivelyJson(child, singleSprite);
- nodedata->children.push_back(tempdata);
- }
- }
- return nodedata;
- }
- bool Bundle3D::loadNodesBinary(NodeDatas& nodedatas)
- {
- if (!seekToFirstType(BUNDLE_TYPE_NODE))
- return false;
- unsigned int nodeSize = 0;
- if (_binaryReader.read(&nodeSize, 4, 1) != 1)
- {
- CCLOG("warning: Failed to read nodes");
- return false;
- }
-
- for (rapidjson::SizeType i = 0; i < nodeSize; ++i)
- {
- bool skeleton = false;
- NodeData* nodedata = parseNodesRecursivelyBinary(skeleton, nodeSize == 1);
- if (skeleton)
- nodedatas.skeleton.push_back(nodedata);
- else
- nodedatas.nodes.push_back(nodedata);
- }
- return true;
- }
- NodeData* Bundle3D::parseNodesRecursivelyBinary(bool& skeleton, bool singleSprite)
- {
-
- std::string id = _binaryReader.readString();
-
- bool skeleton_;
- if (_binaryReader.read(&skeleton_, 1, 1) != 1)
- {
- CCLOG("warning: Failed to read is skeleton");
- return nullptr;
- }
- if (skeleton_)
- skeleton = true;
-
-
- Mat4 transform;
- if (!_binaryReader.readMatrix(transform.m))
- {
- CCLOG("warning: Failed to read transform matrix");
- return nullptr;
- }
-
- unsigned int partsSize = 0;
- if (_binaryReader.read(&partsSize, 4, 1) != 1)
- {
- CCLOG("warning: Failed to read meshdata: attribCount '%s'.", _path.c_str());
- return nullptr;
- }
- NodeData* nodedata = new (std::nothrow) NodeData();
- nodedata->id = id;
-
- bool isSkin = false;
-
- if (partsSize > 0)
- {
- for (unsigned int i = 0; i < partsSize; ++i)
- {
- auto modelnodedata = new (std::nothrow) ModelData();
- modelnodedata->subMeshId = _binaryReader.readString();
- modelnodedata->materialId = _binaryReader.readString();
- if (modelnodedata->subMeshId == "" || modelnodedata->materialId == "")
- {
- std::string err = "Node " + nodedata->id + " part is missing meshPartId or materialId";
- CCLOG("Node %s part is missing meshPartId or materialId", nodedata->id.c_str());
- CC_SAFE_DELETE(modelnodedata);
- CC_SAFE_DELETE(nodedata);
- return nullptr;
- }
-
- unsigned int bonesSize = 0;
- if (_binaryReader.read(&bonesSize, 4, 1) != 1)
- {
- CCLOG("warning: Failed to read meshdata: attribCount '%s'.", _path.c_str());
- CC_SAFE_DELETE(modelnodedata);
- CC_SAFE_DELETE(nodedata);
- return nullptr;
- }
- if (bonesSize > 0)
- {
- for (unsigned int j = 0; j < bonesSize; ++j)
- {
- std::string name = _binaryReader.readString();
- modelnodedata->bones.push_back(name);
- Mat4 invbindpos;
- if (!_binaryReader.readMatrix(invbindpos.m))
- {
- CC_SAFE_DELETE(modelnodedata);
- CC_SAFE_DELETE(nodedata);
- return nullptr;
- }
- modelnodedata->invBindPose.push_back(invbindpos);
- }
- isSkin = true;
- }
- unsigned int uvMapping = 0;
- if (_binaryReader.read(&uvMapping, 4, 1) != 1)
- {
- CCLOG("warning: Failed to read nodedata: uvMapping '%s'.", _path.c_str());
- CC_SAFE_DELETE(modelnodedata);
- CC_SAFE_DELETE(nodedata);
- return nullptr;
- }
- for(unsigned int j = 0; j < uvMapping; ++j)
- {
- unsigned int textureIndexSize=0;
- if (_binaryReader.read(&textureIndexSize, 4, 1) != 1)
- {
- CCLOG("warning: Failed to read meshdata: attribCount '%s'.", _path.c_str());
- CC_SAFE_DELETE(modelnodedata);
- CC_SAFE_DELETE(nodedata);
- return nullptr;
- }
- for(unsigned int k = 0; k < textureIndexSize; ++k)
- {
- unsigned int index=0;
- if (_binaryReader.read(&index, 4, 1) != 1)
- {
- CC_SAFE_DELETE(modelnodedata);
- CC_SAFE_DELETE(nodedata);
- return nullptr;
- }
- }
- }
- nodedata->modelNodeDatas.push_back(modelnodedata);
- }
- }
-
- if(_version == "0.1" || _version == "0.2" || _version == "0.3" || _version == "0.4" || _version == "0.5" || _version == "0.6")
- {
- if(isSkin || singleSprite)
- {
- nodedata->transform = Mat4::IDENTITY;
- }
- else
- {
- nodedata->transform = transform;
- }
- }
- else
- {
- nodedata->transform = transform;
- }
-
- unsigned int childrenSize = 0;
- if (_binaryReader.read(&childrenSize, 4, 1) != 1)
- {
- CCLOG("warning: Failed to read meshdata: attribCount '%s'.", _path.c_str());
- CC_SAFE_DELETE(nodedata);
- return nullptr;
- }
- if (childrenSize > 0)
- {
- for (unsigned int i = 0; i < childrenSize; ++i)
- {
- NodeData* tempdata = parseNodesRecursivelyBinary(skeleton, singleSprite);
- nodedata->children.push_back(tempdata);
- }
- }
- return nodedata;
- }
- GLenum Bundle3D::parseGLType(const std::string& str)
- {
- if (str == "GL_BYTE")
- {
- return GL_BYTE;
- }
- else if(str == "GL_UNSIGNED_BYTE")
- {
- return GL_UNSIGNED_BYTE;
- }
- else if(str == "GL_SHORT")
- {
- return GL_SHORT;
- }
- else if(str == "GL_UNSIGNED_SHORT")
- {
- return GL_UNSIGNED_SHORT;
- }
- else if(str == "GL_INT")
- {
- return GL_INT;
- }
- else if (str == "GL_UNSIGNED_INT")
- {
- return GL_UNSIGNED_INT;
- }
- else if (str == "GL_FLOAT")
- {
- return GL_FLOAT;
- }
- else if (str == "REPEAT")
- {
- return GL_REPEAT;
- }
- else if (str == "CLAMP")
- {
- return GL_CLAMP_TO_EDGE;
- }
- else
- {
- CCASSERT(false, "Invalid GL type");
- return 0;
- }
- }
- NTextureData::Usage Bundle3D::parseGLTextureType(const std::string& str)
- {
- if (str == "AMBIENT")
- {
- return NTextureData::Usage::Ambient;
- }
- else if(str == "BUMP")
- {
- return NTextureData::Usage::Bump;
- }
- else if(str == "DIFFUSE")
- {
- return NTextureData::Usage::Diffuse;
- }
- else if(str == "EMISSIVE")
- {
- return NTextureData::Usage::Emissive;
- }
- else if(str == "NONE")
- {
- return NTextureData::Usage::None;
- }
- else if (str == "NORMAL")
- {
- return NTextureData::Usage::Normal;
- }
- else if (str == "REFLECTION")
- {
- return NTextureData::Usage::Reflection;
- }
- else if (str == "SHININESS")
- {
- return NTextureData::Usage::Shininess;
- }
- else if (str == "SPECULAR")
- {
- return NTextureData::Usage::Specular;
- }
- else if (str == "TRANSPARENCY")
- {
- return NTextureData::Usage::Transparency;
- }
- else
- {
- CCASSERT(false, "Wrong Texture type");
- return NTextureData::Usage::Unknown;
- }
- }
- unsigned int Bundle3D::parseGLProgramAttribute(const std::string& str)
- {
- if (str == "VERTEX_ATTRIB_POSITION")
- {
- return GLProgram::VERTEX_ATTRIB_POSITION;
- }
- else if (str == "VERTEX_ATTRIB_COLOR")
- {
- return GLProgram::VERTEX_ATTRIB_COLOR;
- }
- else if (str == "VERTEX_ATTRIB_TEX_COORD")
- {
- return GLProgram::VERTEX_ATTRIB_TEX_COORD;
- }
- else if (str == "VERTEX_ATTRIB_TEX_COORD1")
- {
- return GLProgram::VERTEX_ATTRIB_TEX_COORD1;
- }
- else if (str == "VERTEX_ATTRIB_TEX_COORD2")
- {
- return GLProgram::VERTEX_ATTRIB_TEX_COORD2;
- }
- else if (str == "VERTEX_ATTRIB_TEX_COORD3")
- {
- return GLProgram::VERTEX_ATTRIB_TEX_COORD3;
- }
-
- else if (str == "VERTEX_ATTRIB_NORMAL")
- {
- return GLProgram::VERTEX_ATTRIB_NORMAL;
- }
- else if (str == "VERTEX_ATTRIB_BLEND_WEIGHT")
- {
- return GLProgram::VERTEX_ATTRIB_BLEND_WEIGHT;
- }
- else if (str == "VERTEX_ATTRIB_BLEND_INDEX")
- {
- return GLProgram::VERTEX_ATTRIB_BLEND_INDEX;
- }
- else if (str == "VERTEX_ATTRIB_TANGENT")
- {
- return GLProgram::VERTEX_ATTRIB_TANGENT;
- }
- else if (str == "VERTEX_ATTRIB_BINORMAL")
- {
- return GLProgram::VERTEX_ATTRIB_BINORMAL;
- }
- else
- {
- CCASSERT(false, "Wrong Attribute type");
- return -1;
- }
- }
- void Bundle3D::getModelRelativePath(const std::string& path)
- {
- ssize_t index = path.find_last_of('/');
- std::string fullModelPath;
- _modelPath = path.substr(0, index + 1);
- }
- Reference* Bundle3D::seekToFirstType(unsigned int type, const std::string& id)
- {
-
- for (unsigned int i = 0; i < _referenceCount; ++i)
- {
- Reference* ref = &_references[i];
- if (ref->type == type)
- {
-
- if (id != "" && id != ref->id)
- {
- continue;
- }
-
-
- if (_binaryReader.seek(ref->offset, SEEK_SET) == false)
- {
- CCLOG("warning: Failed to seek to object '%s' in bundle '%s'.", ref->id.c_str(), _path.c_str());
- return nullptr;
- }
- return ref;
- }
- }
- return nullptr;
- }
- std::vector<Vec3> Bundle3D::getTrianglesList(const std::string& path)
- {
- std::vector<Vec3> trianglesList;
-
- if (path.length() <= 4)
- return trianglesList;
-
- auto bundle = Bundle3D::createBundle();
- std::string ext = FileUtils::getInstance()->getFileExtension(path);
- MeshDatas meshs;
- if (ext == ".obj")
- {
- MaterialDatas materials;
- NodeDatas nodes;
- if (!Bundle3D::loadObj(meshs, materials, nodes, path))
- {
- Bundle3D::destroyBundle(bundle);
- return trianglesList;
- }
- }
- else
- {
- if (!bundle->load(path))
- {
- Bundle3D::destroyBundle(bundle);
- return trianglesList;
- }
-
- bundle->loadMeshDatas(meshs);
-
- }
-
- Bundle3D::destroyBundle(bundle);
- for (auto iter : meshs.meshDatas){
- int preVertexSize = iter->getPerVertexSize() / sizeof(float);
- for (auto indexArray : iter->subMeshIndices){
- for (auto i : indexArray){
- trianglesList.push_back(Vec3(iter->vertex[i * preVertexSize], iter->vertex[i * preVertexSize + 1], iter->vertex[i * preVertexSize + 2]));
- }
- }
- }
-
- return trianglesList;
- }
- Bundle3D::Bundle3D()
- : _modelPath(""),
- _path(""),
- _version(""),
- _referenceCount(0),
- _references(nullptr),
- _isBinary(false)
- {
- }
- Bundle3D::~Bundle3D()
- {
- clear();
- }
- cocos2d::AABB Bundle3D::calculateAABB( const std::vector<float>& vertex, int stride, const std::vector<unsigned short>& index )
- {
- AABB aabb;
- stride /= 4;
- for (const auto& it : index)
- {
- Vec3 point(vertex[it * stride], vertex[it * stride + 1], vertex[it * stride + 2]);
- aabb.updateMinMax(&point, 1);
- }
- return aabb;
- }
- NS_CC_END
|