Fix crash in zone_lighter, index buffer was assumed 32 bit

feature/pre-code-move
kaetemi 5 years ago committed by Jan Boon
parent 1069a5acf9
commit 3ed3841c3a

@ -2,7 +2,7 @@
// Copyright (C) 2010 Winch Gate Property Limited // Copyright (C) 2010 Winch Gate Property Limited
// //
// This source file has been modified by the following contributors: // This source file has been modified by the following contributors:
// Copyright (C) 2013-2014 Jan BOON (Kaetemi) <jan.boon@kaetemi.be> // Copyright (C) 2013-2019 Jan BOON (Kaetemi) <jan.boon@kaetemi.be>
// //
// This program is free software: you can redistribute it and/or modify // This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as // it under the terms of the GNU Affero General Public License as
@ -1765,7 +1765,7 @@ void CZoneLighter::addTriangles (const CMeshBase &meshBase, const CMeshGeom &mes
alphaTestThreshold)); alphaTestThreshold));
} }
} }
else else if (iba.getFormat() == CIndexBuffer::Indices16)
{ {
const uint16* triIndex=(const uint16*)iba.getPtr (); const uint16* triIndex=(const uint16*)iba.getPtr ();
uint numTri=primitive.getNumIndexes ()/3; uint numTri=primitive.getNumIndexes ()/3;
@ -1797,6 +1797,10 @@ void CZoneLighter::addTriangles (const CMeshBase &meshBase, const CMeshGeom &mes
alphaTestThreshold)); alphaTestThreshold));
} }
} }
else
{
nlerror("Invalid index buffer format");
}
} }
} }
} }
@ -1901,34 +1905,73 @@ void CZoneLighter::addTriangles (const CMeshBase &meshBase, const CMeshMRMGeom &
// Dump triangles // Dump triangles
CIndexBufferRead iba; CIndexBufferRead iba;
primitive.lock (iba); primitive.lock (iba);
const uint32* triIndex= (const uint32 *) iba.getPtr (); if (iba.getFormat() == CIndexBuffer::Indices32)
uint numTri=primitive.getNumIndexes ()/3;
uint tri;
for (tri=0; tri<numTri; tri++)
{ {
// Vertex const uint32 *triIndex = (const uint32 *)iba.getPtr();
CVector v0=modelMT*(*vba.getVertexCoordPointer (triIndex[tri*3])); uint numTri = primitive.getNumIndexes() / 3;
CVector v1=modelMT*(*vba.getVertexCoordPointer (triIndex[tri*3+1])); uint tri;
CVector v2=modelMT*(*vba.getVertexCoordPointer (triIndex[tri*3+2])); for (tri = 0; tri < numTri; tri++)
// UV
float u[3] = { 0.f };
float v[3] = { 0.f };
for (uint i=0; i<3; i++)
{ {
// Get UV coordinates // Vertex
float *uv = (float*)vba.getTexCoordPointer (triIndex[tri*3+i], 0); CVector v0 = modelMT * (*vba.getVertexCoordPointer(triIndex[tri * 3]));
if (uv) CVector v1 = modelMT * (*vba.getVertexCoordPointer(triIndex[tri * 3 + 1]));
CVector v2 = modelMT * (*vba.getVertexCoordPointer(triIndex[tri * 3 + 2]));
// UV
float u[3] = { 0.f };
float v[3] = { 0.f };
for (uint i = 0; i < 3; i++)
{ {
// Copy it // Get UV coordinates
u[i] = uv[0]; float *uv = (float *)vba.getTexCoordPointer(triIndex[tri * 3 + i], 0);
v[i] = uv[1]; if (uv)
{
// Copy it
u[i] = uv[0];
v[i] = uv[1];
}
} }
// Make a triangle
triangleArray.push_back(CTriangle(NLMISC::CTriangle(v0, v1, v2), doubleSided, texture, clampU, clampV, u, v,
alphaTestThreshold));
} }
}
else if (iba.getFormat() == CIndexBuffer::Indices16)
{
const uint16 *triIndex = (const uint16 *)iba.getPtr();
uint numTri = primitive.getNumIndexes() / 3;
uint tri;
for (tri = 0; tri < numTri; tri++)
{
// Vertex
CVector v0 = modelMT * (*vba.getVertexCoordPointer(triIndex[tri * 3]));
CVector v1 = modelMT * (*vba.getVertexCoordPointer(triIndex[tri * 3 + 1]));
CVector v2 = modelMT * (*vba.getVertexCoordPointer(triIndex[tri * 3 + 2]));
// UV
float u[3] = { 0.f };
float v[3] = { 0.f };
for (uint i = 0; i < 3; i++)
{
// Get UV coordinates
float *uv = (float *)vba.getTexCoordPointer(triIndex[tri * 3 + i], 0);
if (uv)
{
// Copy it
u[i] = uv[0];
v[i] = uv[1];
}
}
// Make a triangle // Make a triangle
triangleArray.push_back (CTriangle (NLMISC::CTriangle (v0, v1, v2), doubleSided, texture, clampU, clampV, u, v, triangleArray.push_back(CTriangle(NLMISC::CTriangle(v0, v1, v2), doubleSided, texture, clampU, clampV, u, v,
alphaTestThreshold)); alphaTestThreshold));
}
}
else
{
nlerror("Invalid index buffer format");
} }
} }
} }

Loading…
Cancel
Save