gpt4 book ai didi

ios - 纹理未加载到 FBX 中,使用 FBX SDK 导出

转载 作者:行者123 更新时间:2023-11-29 01:40:50 24 4
gpt4 key购买 nike

我正在处理一个 OpenGLES2 项目 (iOS),我必须在其中将场景/模型导出为 FBX 格式,以便可以使用 FBX 审查应用程序打开它。我已经弥补了模型加载的地步,法线和 Material 工作正常,但纹理没有加载。我已使用 iTunes 将导出的修复文件和纹理文件粘贴到 FBX Review 应用程序的文档目录中。以下是我的代码:

素材创作:

FbxString lMaterialName = "material";
FbxString lShadingName = "Phong";
FbxDouble3 lBlack(0.0, 0.0, 0.0);
FbxDouble3 lRed(0.0, 1.0, 0.0);
FbxDouble3 lDiffuseColor(1.0, 1.0, 1.0);
gMaterial = FbxSurfacePhong::Create(pScene, lMaterialName.Buffer());
gMaterial->Emissive.Set(lBlack);
gMaterial->Ambient.Set(lRed);
gMaterial->Diffuse.Set(lDiffuseColor);
gMaterial->TransparencyFactor.Set(40.5);
gMaterial->ShadingModel.Set(lShadingName);
gMaterial->Shininess.Set(0.5);

纹理创建:

gTexture = FbxFileTexture::Create(pScene, "Diffuse Texture");
gTexture->SetFileName("sample.png");
gTexture->SetTextureUse(FbxTexture::eStandard);
gTexture->SetMappingType(FbxTexture::eUV);
gTexture->SetMaterialUse(FbxFileTexture::eModelMaterial);
gTexture->SetSwapUV(false);
gTexture->SetTranslation(0.0, 0.0);
gTexture->SetScale(1.0, 1.0);
gTexture->SetRotation(0.0, 0.0);

创建 FBXLayeredTexture:

finalNode->AddMaterial(gMaterial);
FbxLayeredTexture* layeredTexture = FbxLayeredTexture::Create(fbxManager, "layered texture");
layeredTexture->ConnectSrcObject(gTexture);
layeredTexture->SetMappingType(FbxTexture::eUV);
FbxSurfacePhong* surfMaterial = (FbxSurfacePhong*)sampleNode->GetMaterial(0);
surfMaterial->Diffuse.ConnectSrcObject(layeredTexture);

// Creating FBXLayerElementUV in another method
....
fbxMesh->InitControlPoints(objMesh->getVerticesCount());

FbxLayer* meshLayer = fbxMesh->GetLayer(0);
FbxLayerElementUV* lUVElement1 = FbxLayerElementUV::Create(fbxMesh, "UVSet1");
lUVElement1->SetMappingMode(FbxGeometryElement::eByControlPoint);
lUVElement1->SetReferenceMode(FbxGeometryElement::eDirect);
lUVElement1->GetDirectArray().SetCount(objMesh->getVerticesCount());

for (int index = 0; index < objMesh->getVerticesCount(); index++) {
vertexData* vData = objMesh->getVertexByIndex(index);
Vector3 vPos = vData->vertPosition;
Vector3 vNor = vData->vertNormal;
Vector2 vUV = vData->texCoord1;

fbxMesh->SetControlPointAt(fbxsdk_2015_1::FbxVector4(vPos.x, vPos.y, vPos.z), fbxsdk_2015_1::FbxVector4(vNor.x, vNor.y, vNor.z), index);
//fbxMesh->AddTextureUV(FbxVector2(vUV.x, vUV.y)); // For Trial
lUVElement1->GetDirectArray().Add(FbxVector2(vUV.x, vUV.y));
}
meshLayer->SetUVs(lUVElement1);
// And Finally
...
finalNode->SetNodeAttribute(fbxMesh);
finalNode->SetShadingMode(FbxNode::eTextureShading);

提前致谢。

最佳答案

在这一行中,您应该将“fbxManager”更改为“pScene”:

FbxLayeredTexture* layeredTexture = FbxLayeredTexture::Create(fbxManager, "layered texture"); 

关于ios - 纹理未加载到 FBX 中,使用 FBX SDK 导出,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32412745/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com