diff options
Diffstat (limited to '')
-rw-r--r-- | NW4RTools/ObjExporter.cs | 15 |
1 files changed, 11 insertions, 4 deletions
diff --git a/NW4RTools/ObjExporter.cs b/NW4RTools/ObjExporter.cs index 2bd791c..214f84a 100644 --- a/NW4RTools/ObjExporter.cs +++ b/NW4RTools/ObjExporter.cs @@ -39,10 +39,14 @@ namespace NW4RTools { foreach (var kv in CurrentModel.VtxPosData) { VtxPosOffsets[kv.Value] = Offset; Output.WriteLine("# Vertex Positions: {0} [offset {1}]", kv.Key, Offset); - + for (int i = 0; i < kv.Value.EntryCount; i++) { float[] v = kv.Value.GetEntry(i); - Output.WriteLine("v {0} {1} {2}", v[0], v[1], v[2]); + if (kv.Value.ComponentCount == VertexSettings.CompCount.Position2) { + Output.WriteLine("v {0} {1} 0.0", v[0], v[1]); + } else { + Output.WriteLine("v {0} {1} {2}", v[0], v[1], v[2]); + } } Offset += kv.Value.EntryCount; @@ -140,12 +144,15 @@ namespace NW4RTools { GXIndexedVertex[] vtxs = new GXIndexedVertex[vtxCount]; string[] pVtxs = new string[vtxCount]; + // this is a little hackish, oh well + string nrmPrefix = (vs.NormalDesc == VertexSettings.DescType.None) ? "" : "/"; + for (int i = 0; i < vtxCount; i++) { vtxs[i].LoadFrom(dl, vs); string tc = (vtxs[i].TexCoords[0] == -1) ? "" : (tcOffset + vtxs[i].TexCoords[0]).ToString(); - string n = (vtxs[i].Normal == -1) ? "" : (nrmOffset + vtxs[i].Normal).ToString(); - pVtxs[i] = String.Format(" {0}/{1}/{2}", posOffset + vtxs[i].Position, tc, n); + string n = (vtxs[i].Normal == -1) ? "" : "/" + (nrmOffset + vtxs[i].Normal).ToString(); + pVtxs[i] = String.Format(" {0}/{1}{2}{3}", posOffset + vtxs[i].Position, tc, nrmPrefix, n); } switch (prim) { |