Browse Source

plStringify ControllerDebugDisplay.

plStringification of plPXPhysicalControllerCore::IDrawDebugDisplay
and general clean-up.  Also changed to only display
avatar collisions heading if any exist to show.
Joseph Davies 12 years ago
parent
commit
e2a0041d31
  1. 44
      Sources/Plasma/PubUtilLib/plPhysX/plPXPhysicalControllerCore.cpp

44
Sources/Plasma/PubUtilLib/plPhysX/plPXPhysicalControllerCore.cpp

@ -849,33 +849,35 @@ void plPXPhysicalControllerCore::IProcessDynamicHits()
void plPXPhysicalControllerCore::IDrawDebugDisplay() void plPXPhysicalControllerCore::IDrawDebugDisplay()
{ {
plDebugText &debugTxt = plDebugText::Instance(); plDebugText &debugTxt = plDebugText::Instance();
char strBuf[ 2048 ]; plString debugString;
int lineHeight = debugTxt.GetFontSize() + 4; int y = 10; // Initial draw position
uint32_t scrnWidth, scrnHeight;
debugTxt.GetScreenSize( &scrnWidth, &scrnHeight );
int y = 10;
int x = 10; int x = 10;
int lineHeight = debugTxt.GetFontSize() + 4;
sprintf(strBuf, "Controller Count: %d", gControllers.size()); debugString = plString::Format("Controller Count: %d", gControllers.size());
debugTxt.DrawString(x, y, strBuf); debugTxt.DrawString(x, y, debugString.c_str());
y += lineHeight;
debugTxt.DrawString(x, y, "Avatar Collisions:");
y += lineHeight; y += lineHeight;
int i; // Only display avatar collisions if any exist...
for (i = 0; i < fDbgCollisionInfo.GetCount(); i++) int collisionCount = fDbgCollisionInfo.GetCount();
if (collisionCount > 0)
{ {
hsVector3 normal = fDbgCollisionInfo[i].fNormal; debugTxt.DrawString(x, y, "Avatar Collisions:");
char *overlapStr = fDbgCollisionInfo[i].fOverlap ? "yes" : "no";
float angle = hsRadiansToDegrees(acos(normal * hsVector3(0, 0, 1)));
sprintf(strBuf, " Obj: %s, Normal: (%.2f, %.2f, %.2f), Angle(%.1f), Overlap(%3s)",
fDbgCollisionInfo[i].fSO->GetKeyName().c_str(),
normal.fX, normal.fY, normal.fZ, angle, overlapStr);
debugTxt.DrawString(x, y, strBuf);
y += lineHeight; y += lineHeight;
for (int i = 0; i < collisionCount; i++)
{
hsVector3 normal = fDbgCollisionInfo[i].fNormal;
const char* overlapStr = fDbgCollisionInfo[i].fOverlap ? "yes" : "no";
float angle = hsRadiansToDegrees(acos(normal * hsVector3(0, 0, 1)));
debugString = plString::Format("\tObj: %s, Normal: (%.2f, %.2f, %.2f), Angle(%.1f), Overlap(%s)",
fDbgCollisionInfo[i].fSO->GetKeyName().c_str(),
normal.fX, normal.fY, normal.fZ, angle,
overlapStr);
debugTxt.DrawString(x, y, debugString.c_str());
y += lineHeight;
}
} }
} }
#endif PLASMA_EXTERNAL_RELEASE #endif PLASMA_EXTERNAL_RELEASE

Loading…
Cancel
Save