我编写了一个自定义的 OBJ 文件导入器,它运行得相当好,但不够强大,无法支持所有内容。我决定给 AssImp 一个机会。我遵循了一些教程并设置了我的代码以读取我已成功使用自定义导入器加载的 OBJ 立方体模型的顶点、tex 坐标、法线和索引。立方体模型的面没有正确渲染,而是只渲染了立方体的几个三角形。AssImp 处理数据的方式显然与我的解决方案有点不同,因为法线、位置/顶点、tex 坐标和索引与我的自定义解决方案不匹配。我非常感谢您了解我遇到问题的原因,因为我发现的所有教程都与我的方法相匹配。如果错误渲染的立方体的图片会有所帮助,我可以制作屏幕截图。谢谢你。
我的资产导入类:
module graphics.assimp;
import std.stdio, std.container, std.range;
import core, graphics;
import derelict.assimp3.assimp;
class AssImp
{
this()
{
DerelictASSIMP3.load();
}
IndexedModel makeIndexedModel(vec3[] verts, vec3[] norms, vec2[] uvs, uint[] indices)
{
IndexedModel model;
model.pos = verts;
model.normals = norms;
model.texCoords = uvs;
model.indices = indices;
writeln("verts: ", model.pos);
writeln("normals: ", model.normals);
writeln("texCoords: ", model.texCoords);
writeln("indices: ", model.indices);
return model;
}
Mesh loadMesh(const char* fileName)
{
const aiScene* scene = aiImportFile(fileName, aiProcessPreset_TargetRealtime_Fast | aiProcess_Triangulate | aiProcess_JoinIdenticalVertices);
const aiMesh* mesh = scene.mMeshes[0];
numVerts = mesh.mNumFaces * 3;
vertArray = new vec3[mesh.mNumFaces];
normalArray = new vec3[mesh.mNumFaces];
uvArray = new vec2[mesh.mNumFaces];
int indexCount;
for (uint i = 0; i < mesh.mNumFaces; i++)
{
const aiFace face = mesh.mFaces[i];
indexCount += face.mNumIndices;
for (int j = 0; j < 3; j++)
{
aiVector3D uv = mesh.mTextureCoords[0][face.mIndices[j]];
uvArray[i] = vec2(uv.x, uv.y);
aiVector3D normal = mesh.mNormals[face.mIndices[j]];
normalArray[i] = vec3(normal.x, normal.y, normal.z);
aiVector3D pos = mesh.mVertices[face.mIndices[j]];
vertArray[i] = vec3(pos.x, pos.y, pos.z);
indices.insert(face.mIndices[j]);
}
}
return new Mesh(makeIndexedModel(vertArray, normalArray, uvArray, indices.array));
}
private:
vec3 vertArray[];
vec3 normalArray[];
vec2 uvArray[];
auto indices = make!(Array!uint)();
int numVerts;
}
我的其余代码位于(Mesh Class 在源代码/图形中): https ://github.com/BennetLeff/PhySim