Skip to content

Commit

Permalink
Add getPoints & getIndices to ConvexShape
Browse files Browse the repository at this point in the history
  • Loading branch information
xiejiangzhi committed Dec 27, 2024
1 parent c74c1c3 commit aaa9161
Show file tree
Hide file tree
Showing 4 changed files with 85 additions and 0 deletions.
31 changes: 31 additions & 0 deletions src/api/l_physics_shapes.c
Original file line number Diff line number Diff line change
Expand Up @@ -536,6 +536,20 @@ static int l_lovrConvexShapeGetPoint(lua_State* L) {
return 3;
}

static int l_lovrConvexShapeGetPoints(lua_State* L) {
ConvexShape* convex = luax_checktype(L, 1, ConvexShape);
uint32_t count = lovrConvexShapeGetPointCount(convex);
float* points = lovrMalloc(count * 3 * sizeof(uint32_t));
luax_assert(L, lovrConvexShapeGetPoints(convex, points));
lua_createtable(L, (int) count * 3, 0);
for (uint32_t i = 0; i < count * 3; i++) {
lua_pushnumber(L, points[i]);
lua_rawseti(L, -2, i + 1);
}
lovrFree(points);
return 1;
}

static int l_lovrConvexShapeGetFaceCount(lua_State* L) {
ConvexShape* convex = luax_checktype(L, 1, ConvexShape);
uint32_t count = lovrConvexShapeGetFaceCount(convex);
Expand All @@ -562,6 +576,21 @@ static int l_lovrConvexShapeGetFace(lua_State* L) {
return 1;
}

static int l_lovrConvexShapeGetIndices(lua_State* L) {
ConvexShape* convex = luax_checktype(L, 1, ConvexShape);
uint32_t icount, maxFaceVcount;
lovrConvexShapeGetIndicesCount(convex, &icount, &maxFaceVcount);
uint32_t* indices = lovrMalloc(icount * sizeof(uint32_t));
luax_assert(L, lovrConvexShapeGetIndices(convex, indices, maxFaceVcount));
lua_createtable(L, (int)icount, 0);
for (uint32_t i = 0; i < icount; i++) {
lua_pushnumber(L, indices[i] + 1);
lua_rawseti(L, -2, i + 1);
}
lovrFree(indices);
return 1;
}

static int l_lovrConvexShapeGetScale(lua_State* L) {
ConvexShape* convex = luax_checktype(L, 1, ConvexShape);
float scale = lovrConvexShapeGetScale(convex);
Expand All @@ -573,8 +602,10 @@ const luaL_Reg lovrConvexShape[] = {
lovrShape,
{ "getPointCount", l_lovrConvexShapeGetPointCount },
{ "getPoint", l_lovrConvexShapeGetPoint },
{ "getPoints", l_lovrConvexShapeGetPoints },
{ "getFaceCount", l_lovrConvexShapeGetFaceCount },
{ "getFace", l_lovrConvexShapeGetFace },
{ "getIndices", l_lovrConvexShapeGetIndices },
{ "getScale", l_lovrConvexShapeGetScale },
{ NULL, NULL }
};
Expand Down
39 changes: 39 additions & 0 deletions src/modules/physics/physics.c
Original file line number Diff line number Diff line change
Expand Up @@ -2309,6 +2309,16 @@ bool lovrConvexShapeGetPoint(ConvexShape* shape, uint32_t index, float point[3])
return true;
}

bool lovrConvexShapeGetPoints(ConvexShape* shape, float* points) {
const JPH_ConvexHullShape* hull = (const JPH_ConvexHullShape*) JPH_DecoratedShape_GetInnerShape((const JPH_DecoratedShape*) shape->handle);
JPH_Vec3 v;
for (int i = 0; i < JPH_ConvexHullShape_GetNumPoints(hull); i++) {
JPH_ConvexHullShape_GetPoint(hull, i, &v);
vec3_fromJolt(points + i * 3, &v);
}
return true;
}

uint32_t lovrConvexShapeGetFaceCount(ConvexShape* shape) {
const JPH_ConvexHullShape* hull = (const JPH_ConvexHullShape*) JPH_DecoratedShape_GetInnerShape((const JPH_DecoratedShape*) shape->handle);
return JPH_ConvexHullShape_GetNumFaces(hull);
Expand All @@ -2320,6 +2330,35 @@ uint32_t lovrConvexShapeGetFace(ConvexShape* shape, uint32_t index, uint32_t* po
return JPH_ConvexHullShape_GetFaceVertices(hull, index, capacity, pointIndices);
}

bool lovrConvexShapeGetIndicesCount(ConvexShape* shape, uint32_t* icount, uint32_t* maxFaceVcount) {
const JPH_ConvexHullShape* hull = (const JPH_ConvexHullShape*) JPH_DecoratedShape_GetInnerShape((const JPH_DecoratedShape*) shape->handle);
*icount = 0;
*maxFaceVcount = 0;
for (int i = 0; i < JPH_ConvexHullShape_GetNumFaces(hull); i++) {
int n = JPH_ConvexHullShape_GetNumVerticesInFace(hull, i);
*maxFaceVcount = MAX(*maxFaceVcount, n);
*icount = *icount + (n - 2) * 3;
}
return true;
}

bool lovrConvexShapeGetIndices(ConvexShape* shape, uint32_t* indices, uint32_t maxFaceVcount) {
const JPH_ConvexHullShape* hull = (const JPH_ConvexHullShape*) JPH_DecoratedShape_GetInnerShape((const JPH_DecoratedShape*) shape->handle);
uint32_t* fvs = lovrMalloc(maxFaceVcount * sizeof(uint32_t));
uint32_t idx = 0;
for (int i = 0; i < JPH_ConvexHullShape_GetNumFaces(hull); i++) {
int n = JPH_ConvexHullShape_GetFaceVertices(hull, i, maxFaceVcount, fvs);
for (int i = 2; i < n; i++) {
indices[idx] = fvs[0];
indices[idx + 1] = fvs[i - 1];
indices[idx + 2] = fvs[i];
idx += 3;
}
}
lovrFree(fvs);
return true;
}

float lovrConvexShapeGetScale(ConvexShape* shape) {
JPH_Vec3 v;
JPH_ScaledShape_GetScale((JPH_ScaledShape*) shape->handle, &v);
Expand Down
3 changes: 3 additions & 0 deletions src/modules/physics/physics.h
Original file line number Diff line number Diff line change
Expand Up @@ -258,8 +258,11 @@ ConvexShape* lovrConvexShapeCreate(float points[], uint32_t count, float scale);
ConvexShape* lovrConvexShapeClone(ConvexShape* parent, float scale);
uint32_t lovrConvexShapeGetPointCount(ConvexShape* shape);
bool lovrConvexShapeGetPoint(ConvexShape* shape, uint32_t index, float point[3]);
bool lovrConvexShapeGetPoints(ConvexShape* shape, float* point);
uint32_t lovrConvexShapeGetFaceCount(ConvexShape* shape);
uint32_t lovrConvexShapeGetFace(ConvexShape* shape, uint32_t index, uint32_t* pointIndices, uint32_t capacity);
bool lovrConvexShapeGetIndicesCount(ConvexShape* shape, uint32_t* icount, uint32_t* maxFaceVcount);
bool lovrConvexShapeGetIndices(ConvexShape* shape, uint32_t* indices, uint32_t maxFaceVcount);
float lovrConvexShapeGetScale(ConvexShape* shape);

MeshShape* lovrMeshShapeCreate(uint32_t vertexCount, float vertices[], uint32_t indexCount, uint32_t indices[], float scale);
Expand Down
12 changes: 12 additions & 0 deletions test/lovr/physics.lua
Original file line number Diff line number Diff line change
Expand Up @@ -98,6 +98,18 @@ group('physics', function()
mesh:setIndices({ 1, 2, 3, 1, 3, 4, 1, 2, 4, 2, 3, 4 })
shape = lovr.physics.newConvexShape(mesh)
expect(shape:getPointCount()).to.equal(4)
expect(shape:getPoints()).to.equal({
1, 0.5, -0.25,
0, -0.5, 0.75,
0, -0.5, -0.25,
-1, 0.5, -0.25
})
expect(shape:getIndices()).to.equal({
1, 2, 3,
2, 4, 3,
4, 1, 3,
1, 4, 2
})
end
end)

Expand Down

0 comments on commit aaa9161

Please sign in to comment.