mirror of https://github.com/axmolengine/axmol.git
Read AABB Info From Model File(obj/c3t/c3b)
This commit is contained in:
parent
4eb5a6c59b
commit
d5805fbce8
|
@ -87,6 +87,7 @@ static const char* TRANSLATION = "translation";
|
||||||
static const char* ROTATION = "rotation";
|
static const char* ROTATION = "rotation";
|
||||||
static const char* SCALE = "scale";
|
static const char* SCALE = "scale";
|
||||||
static const char* KEYTIME = "keytime";
|
static const char* KEYTIME = "keytime";
|
||||||
|
static const char* AABBS = "aabb";
|
||||||
|
|
||||||
NS_CC_BEGIN
|
NS_CC_BEGIN
|
||||||
|
|
||||||
|
@ -289,8 +290,8 @@ bool Bundle3D::loadObj(MeshDatas& meshdatas, MaterialDatas& materialdatas, NodeD
|
||||||
materialdata.textures.push_back(tex);
|
materialdata.textures.push_back(tex);
|
||||||
materialdata.id = str;
|
materialdata.id = str;
|
||||||
materialdatas.materials.push_back(materialdata);
|
materialdatas.materials.push_back(materialdata);
|
||||||
|
|
||||||
meshdata->subMeshIndices.push_back(it.mesh.indices);
|
meshdata->subMeshIndices.push_back(it.mesh.indices);
|
||||||
|
meshdata->subMeshAABB.push_back(calculateAABB(meshdata->vertex, meshdata->getPerVertexSize(), it.mesh.indices));
|
||||||
meshdata->subMeshIds.push_back(str);
|
meshdata->subMeshIds.push_back(str);
|
||||||
auto node = new (std::nothrow) NodeData();
|
auto node = new (std::nothrow) NodeData();
|
||||||
auto modelnode = new (std::nothrow) ModelData();
|
auto modelnode = new (std::nothrow) ModelData();
|
||||||
|
@ -344,6 +345,10 @@ bool Bundle3D::loadMeshDatas(MeshDatas& meshdatas)
|
||||||
{
|
{
|
||||||
return loadMeshDatasBinary_0_1(meshdatas);
|
return loadMeshDatasBinary_0_1(meshdatas);
|
||||||
}
|
}
|
||||||
|
else if (_version == "0.5")
|
||||||
|
{
|
||||||
|
return loadMeshDatasBinary_0_5(meshdatas);
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
return loadMeshDatasBinary(meshdatas);
|
return loadMeshDatasBinary(meshdatas);
|
||||||
|
@ -375,6 +380,7 @@ bool Bundle3D::loadMeshDatasBinary(MeshDatas& meshdatas)
|
||||||
for(int i = 0; i < meshSize ; i++ )
|
for(int i = 0; i < meshSize ; i++ )
|
||||||
{
|
{
|
||||||
MeshData* meshData = new (std::nothrow) MeshData();
|
MeshData* meshData = new (std::nothrow) MeshData();
|
||||||
|
|
||||||
unsigned int attribSize=0;
|
unsigned int attribSize=0;
|
||||||
// read mesh data
|
// read mesh data
|
||||||
if (_binaryReader.read(&attribSize, 4, 1) != 1 || attribSize < 1)
|
if (_binaryReader.read(&attribSize, 4, 1) != 1 || attribSize < 1)
|
||||||
|
@ -665,6 +671,102 @@ bool Bundle3D::loadMeshDatasBinary_0_2(MeshDatas& meshdatas)
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool Bundle3D::loadMeshDatasBinary_0_5( 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;
|
||||||
|
}
|
||||||
|
for(int i = 0; i < meshSize ; i++ )
|
||||||
|
{
|
||||||
|
MeshData* meshData = new (std::nothrow) MeshData();
|
||||||
|
|
||||||
|
unsigned int attribSize=0;
|
||||||
|
// read mesh data
|
||||||
|
if (_binaryReader.read(&attribSize, 4, 1) != 1 || attribSize < 1)
|
||||||
|
{
|
||||||
|
CCLOG("warning: Failed to read meshdata: attribCount '%s'.", _path.c_str());
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
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());
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
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;
|
||||||
|
// Read vertex data
|
||||||
|
if (_binaryReader.read(&vertexSizeInFloat, 4, 1) != 1 || vertexSizeInFloat == 0)
|
||||||
|
{
|
||||||
|
CCLOG("warning: Failed to read meshdata: vertexSizeInFloat '%s'.", _path.c_str());
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
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());
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Read index data
|
||||||
|
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 aabbSize=0;
|
||||||
|
//read mesh aabb
|
||||||
|
if (_binaryReader.read(&aabbSize, 4, 1) != 1 || aabbSize < 6)
|
||||||
|
{
|
||||||
|
CCLOG("warning: Failed to read meshdata: aabb '%s'.", _path.c_str());
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
float aabb[6];
|
||||||
|
_binaryReader.read(aabb, 4, 6);
|
||||||
|
meshData->subMeshAABB.push_back(AABB(Vec3(aabb[0], aabb[1], aabb[2]), Vec3(aabb[3], aabb[4], aabb[5])));
|
||||||
|
|
||||||
|
unsigned int nIndexCount;
|
||||||
|
if (_binaryReader.read(&nIndexCount, 4, 1) != 1)
|
||||||
|
{
|
||||||
|
CCLOG("warning: Failed to read meshdata: nIndexCount '%s'.", _path.c_str());
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
indexArray.resize(nIndexCount);
|
||||||
|
if (_binaryReader.read(&indexArray[0], 2, nIndexCount) != nIndexCount)
|
||||||
|
{
|
||||||
|
CCLOG("warning: Failed to read meshdata: indices '%s'.", _path.c_str());
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
meshData->subMeshIndices.push_back(indexArray);
|
||||||
|
meshData->numIndex = (int)meshData->subMeshIndices.size();
|
||||||
|
}
|
||||||
|
meshdatas.meshDatas.push_back(meshData);
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
bool Bundle3D::loadMeshDatasJson(MeshDatas& meshdatas)
|
bool Bundle3D::loadMeshDatasJson(MeshDatas& meshdatas)
|
||||||
{
|
{
|
||||||
const rapidjson::Value& mesh_data_array = _jsonReader[MESHES];
|
const rapidjson::Value& mesh_data_array = _jsonReader[MESHES];
|
||||||
|
@ -672,6 +774,7 @@ bool Bundle3D::loadMeshDatasJson(MeshDatas& meshdatas)
|
||||||
{
|
{
|
||||||
MeshData* meshData = new (std::nothrow) MeshData();
|
MeshData* meshData = new (std::nothrow) MeshData();
|
||||||
const rapidjson::Value& mesh_data = mesh_data_array[index];
|
const rapidjson::Value& mesh_data = mesh_data_array[index];
|
||||||
|
|
||||||
// mesh_vertex_attribute
|
// mesh_vertex_attribute
|
||||||
const rapidjson::Value& mesh_vertex_attribute = mesh_data[ATTRIBUTES];
|
const rapidjson::Value& mesh_vertex_attribute = mesh_data[ATTRIBUTES];
|
||||||
MeshVertexAttrib tempAttrib;
|
MeshVertexAttrib tempAttrib;
|
||||||
|
@ -707,6 +810,14 @@ bool Bundle3D::loadMeshDatasJson(MeshDatas& meshdatas)
|
||||||
std::vector<unsigned short> indexArray;
|
std::vector<unsigned short> indexArray;
|
||||||
const rapidjson::Value& mesh_part = mesh_part_array[i];
|
const rapidjson::Value& mesh_part = mesh_part_array[i];
|
||||||
meshData->subMeshIds.push_back(mesh_part[ID].GetString());
|
meshData->subMeshIds.push_back(mesh_part[ID].GetString());
|
||||||
|
//mesh_aabb
|
||||||
|
const rapidjson::Value& mesh_part_aabb = mesh_part[AABBS];
|
||||||
|
if (mesh_part_aabb.Size() == 6)
|
||||||
|
{
|
||||||
|
Vec3 min = Vec3(mesh_part_aabb[(rapidjson::SizeType)0].GetDouble(), mesh_part_aabb[(rapidjson::SizeType)1].GetDouble(), mesh_part_aabb[(rapidjson::SizeType)2].GetDouble());
|
||||||
|
Vec3 max = Vec3(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));
|
||||||
|
}
|
||||||
// index_number
|
// index_number
|
||||||
const rapidjson::Value& indices_val_array = mesh_part[INDICES];
|
const rapidjson::Value& indices_val_array = mesh_part[INDICES];
|
||||||
for (rapidjson::SizeType j = 0; j < indices_val_array.Size(); j++)
|
for (rapidjson::SizeType j = 0; j < indices_val_array.Size(); j++)
|
||||||
|
@ -1976,4 +2087,16 @@ Bundle3D::~Bundle3D()
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
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 = Vec3(vertex[it * stride ], vertex[ it * stride + 1], vertex[it * stride + 2 ]);
|
||||||
|
aabb.updateMinMax(&point, 1);
|
||||||
|
}
|
||||||
|
return aabb;
|
||||||
|
}
|
||||||
|
|
||||||
NS_CC_END
|
NS_CC_END
|
||||||
|
|
|
@ -90,6 +90,7 @@ protected:
|
||||||
bool loadMeshDatasBinary(MeshDatas& meshdatas);
|
bool loadMeshDatasBinary(MeshDatas& meshdatas);
|
||||||
bool loadMeshDatasBinary_0_1(MeshDatas& meshdatas);
|
bool loadMeshDatasBinary_0_1(MeshDatas& meshdatas);
|
||||||
bool loadMeshDatasBinary_0_2(MeshDatas& meshdatas);
|
bool loadMeshDatasBinary_0_2(MeshDatas& meshdatas);
|
||||||
|
bool loadMeshDatasBinary_0_5(MeshDatas& meshdatas);
|
||||||
bool loadMaterialsJson(MaterialDatas& materialdatas);
|
bool loadMaterialsJson(MaterialDatas& materialdatas);
|
||||||
bool loadMaterialDataJson_0_1(MaterialDatas& materialdatas);
|
bool loadMaterialDataJson_0_1(MaterialDatas& materialdatas);
|
||||||
bool loadMaterialDataJson_0_2(MaterialDatas& materialdatas);
|
bool loadMaterialDataJson_0_2(MaterialDatas& materialdatas);
|
||||||
|
@ -153,6 +154,8 @@ CC_CONSTRUCTOR_ACCESS:
|
||||||
Bundle3D();
|
Bundle3D();
|
||||||
virtual ~Bundle3D();
|
virtual ~Bundle3D();
|
||||||
|
|
||||||
|
static AABB calculateAABB(const std::vector<float>& vertex, int stride, const std::vector<unsigned short>& index);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
static Bundle3D* _instance;
|
static Bundle3D* _instance;
|
||||||
std::string _modelPath;
|
std::string _modelPath;
|
||||||
|
|
|
@ -28,6 +28,7 @@
|
||||||
#include "base/CCRef.h"
|
#include "base/CCRef.h"
|
||||||
#include "base/ccTypes.h"
|
#include "base/ccTypes.h"
|
||||||
#include "math/CCMath.h"
|
#include "math/CCMath.h"
|
||||||
|
#include "CCAABB.h"
|
||||||
|
|
||||||
#include <vector>
|
#include <vector>
|
||||||
#include <map>
|
#include <map>
|
||||||
|
@ -122,6 +123,7 @@ struct MeshData
|
||||||
int vertexSizeInFloat;
|
int vertexSizeInFloat;
|
||||||
std::vector<IndexArray> subMeshIndices;
|
std::vector<IndexArray> subMeshIndices;
|
||||||
std::vector<std::string> subMeshIds; //subMesh Names (since 3.3)
|
std::vector<std::string> subMeshIds; //subMesh Names (since 3.3)
|
||||||
|
std::vector<AABB> subMeshAABB;
|
||||||
int numIndex;
|
int numIndex;
|
||||||
std::vector<MeshVertexAttrib> attribs;
|
std::vector<MeshVertexAttrib> attribs;
|
||||||
int attribCount;
|
int attribCount;
|
||||||
|
@ -140,6 +142,7 @@ public:
|
||||||
{
|
{
|
||||||
vertex.clear();
|
vertex.clear();
|
||||||
subMeshIndices.clear();
|
subMeshIndices.clear();
|
||||||
|
subMeshAABB.clear();
|
||||||
attribs.clear();
|
attribs.clear();
|
||||||
vertexSizeInFloat = 0;
|
vertexSizeInFloat = 0;
|
||||||
numIndex = 0;
|
numIndex = 0;
|
||||||
|
|
|
@ -111,7 +111,11 @@ MeshVertexData* MeshVertexData::create(const MeshData& meshdata)
|
||||||
auto& index = meshdata.subMeshIndices[i];
|
auto& index = meshdata.subMeshIndices[i];
|
||||||
auto indexBuffer = IndexBuffer::create(IndexBuffer::IndexType::INDEX_TYPE_SHORT_16, (int)(index.size()));
|
auto indexBuffer = IndexBuffer::create(IndexBuffer::IndexType::INDEX_TYPE_SHORT_16, (int)(index.size()));
|
||||||
indexBuffer->updateIndices(&index[0], (int)index.size(), 0);
|
indexBuffer->updateIndices(&index[0], (int)index.size(), 0);
|
||||||
aabb = MeshVertexData::calculateAABB(meshdata.vertex, meshdata.getPerVertexSize(), index);
|
auto subAABB = meshdata.subMeshAABB[i];
|
||||||
|
if (subAABB.isEmpty())
|
||||||
|
aabb = MeshVertexData::calculateAABB(meshdata.vertex, meshdata.getPerVertexSize(), index);
|
||||||
|
else
|
||||||
|
aabb = subAABB;
|
||||||
std::string id = (i < meshdata.subMeshIds.size() ? meshdata.subMeshIds[i] : "");
|
std::string id = (i < meshdata.subMeshIds.size() ? meshdata.subMeshIds[i] : "");
|
||||||
MeshIndexData* indexdata = MeshIndexData::create(id, vertexdata, indexBuffer, aabb);
|
MeshIndexData* indexdata = MeshIndexData::create(id, vertexdata, indexBuffer, aabb);
|
||||||
vertexdata->_indexs.pushBack(indexdata);
|
vertexdata->_indexs.pushBack(indexdata);
|
||||||
|
|
Loading…
Reference in New Issue