implemented col line rendering
This commit is contained in:
parent
59145cea83
commit
0ad39c020c
@ -18,6 +18,7 @@
|
|||||||
#include "CutsceneMgr.h"
|
#include "CutsceneMgr.h"
|
||||||
#include "RenderBuffer.h"
|
#include "RenderBuffer.h"
|
||||||
#include "SurfaceTable.h"
|
#include "SurfaceTable.h"
|
||||||
|
#include "Lines.h"
|
||||||
#include "Collision.h"
|
#include "Collision.h"
|
||||||
|
|
||||||
enum Direction
|
enum Direction
|
||||||
@ -1387,6 +1388,223 @@ CCollision::CalculateTrianglePlanes(CColModel *model)
|
|||||||
void
|
void
|
||||||
CCollision::DrawColModel(const CMatrix &mat, const CColModel &colModel)
|
CCollision::DrawColModel(const CMatrix &mat, const CColModel &colModel)
|
||||||
{
|
{
|
||||||
|
int i;
|
||||||
|
CVector min, max;
|
||||||
|
CVector verts[8];
|
||||||
|
CVector c;
|
||||||
|
float r;
|
||||||
|
|
||||||
|
RwRenderStateSet(rwRENDERSTATEZWRITEENABLE, (void*)TRUE);
|
||||||
|
RwRenderStateSet(rwRENDERSTATEVERTEXALPHAENABLE, (void*)TRUE);
|
||||||
|
RwRenderStateSet(rwRENDERSTATESRCBLEND, (void*)rwBLENDSRCALPHA);
|
||||||
|
RwRenderStateSet(rwRENDERSTATEDESTBLEND, (void*)rwBLENDINVSRCALPHA);
|
||||||
|
RwRenderStateSet(rwRENDERSTATETEXTURERASTER, nil);
|
||||||
|
|
||||||
|
min = colModel.boundingBox.min;
|
||||||
|
max = colModel.boundingBox.max;
|
||||||
|
|
||||||
|
verts[0] = mat * CVector(min.x, min.y, min.z);
|
||||||
|
verts[1] = mat * CVector(min.x, min.y, max.z);
|
||||||
|
verts[2] = mat * CVector(min.x, max.y, min.z);
|
||||||
|
verts[3] = mat * CVector(min.x, max.y, max.z);
|
||||||
|
verts[4] = mat * CVector(max.x, min.y, min.z);
|
||||||
|
verts[5] = mat * CVector(max.x, min.y, max.z);
|
||||||
|
verts[6] = mat * CVector(max.x, max.y, min.z);
|
||||||
|
verts[7] = mat * CVector(max.x, max.y, max.z);
|
||||||
|
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
verts[0].x, verts[0].y, verts[0].z,
|
||||||
|
verts[1].x, verts[1].y, verts[1].z,
|
||||||
|
0xFF0000FF, 0xFF0000FF);
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
verts[1].x, verts[1].y, verts[1].z,
|
||||||
|
verts[3].x, verts[3].y, verts[3].z,
|
||||||
|
0xFF0000FF, 0xFF0000FF);
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
verts[3].x, verts[3].y, verts[3].z,
|
||||||
|
verts[2].x, verts[2].y, verts[2].z,
|
||||||
|
0xFF0000FF, 0xFF0000FF);
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
verts[2].x, verts[2].y, verts[2].z,
|
||||||
|
verts[0].x, verts[0].y, verts[0].z,
|
||||||
|
0xFF0000FF, 0xFF0000FF);
|
||||||
|
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
verts[4].x, verts[4].y, verts[4].z,
|
||||||
|
verts[5].x, verts[5].y, verts[5].z,
|
||||||
|
0xFF0000FF, 0xFF0000FF);
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
verts[5].x, verts[5].y, verts[5].z,
|
||||||
|
verts[7].x, verts[7].y, verts[7].z,
|
||||||
|
0xFF0000FF, 0xFF0000FF);
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
verts[7].x, verts[7].y, verts[7].z,
|
||||||
|
verts[6].x, verts[6].y, verts[6].z,
|
||||||
|
0xFF0000FF, 0xFF0000FF);
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
verts[6].x, verts[6].y, verts[6].z,
|
||||||
|
verts[4].x, verts[4].y, verts[4].z,
|
||||||
|
0xFF0000FF, 0xFF0000FF);
|
||||||
|
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
verts[0].x, verts[0].y, verts[0].z,
|
||||||
|
verts[4].x, verts[4].y, verts[4].z,
|
||||||
|
0xFF0000FF, 0xFF0000FF);
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
verts[1].x, verts[1].y, verts[1].z,
|
||||||
|
verts[5].x, verts[5].y, verts[5].z,
|
||||||
|
0xFF0000FF, 0xFF0000FF);
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
verts[2].x, verts[2].y, verts[2].z,
|
||||||
|
verts[6].x, verts[6].y, verts[6].z,
|
||||||
|
0xFF0000FF, 0xFF0000FF);
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
verts[3].x, verts[3].y, verts[3].z,
|
||||||
|
verts[7].x, verts[7].y, verts[7].z,
|
||||||
|
0xFF0000FF, 0xFF0000FF);
|
||||||
|
|
||||||
|
for(i = 0; i < colModel.numSpheres; i++){
|
||||||
|
c = mat * colModel.spheres[i].center;
|
||||||
|
r = colModel.spheres[i].radius;
|
||||||
|
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
c.x, c.y, c.z-r,
|
||||||
|
c.x-r, c.y-r, c.z,
|
||||||
|
0xFF00FFFF, 0xFF00FFFF);
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
c.x, c.y, c.z-r,
|
||||||
|
c.x-r, c.y+r, c.z,
|
||||||
|
0xFF00FFFF, 0xFF00FFFF);
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
c.x, c.y, c.z-r,
|
||||||
|
c.x+r, c.y-r, c.z,
|
||||||
|
0xFF00FFFF, 0xFF00FFFF);
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
c.x, c.y, c.z-r,
|
||||||
|
c.x+r, c.y+r, c.z,
|
||||||
|
0xFF00FFFF, 0xFF00FFFF);
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
c.x-r, c.y-r, c.z,
|
||||||
|
c.x, c.y, c.z+r,
|
||||||
|
0xFF00FFFF, 0xFF00FFFF);
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
c.x-r, c.y+r, c.z,
|
||||||
|
c.x, c.y, c.z+r,
|
||||||
|
0xFF00FFFF, 0xFF00FFFF);
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
c.x+r, c.y-r, c.z,
|
||||||
|
c.x, c.y, c.z+r,
|
||||||
|
0xFF00FFFF, 0xFF00FFFF);
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
c.x+r, c.y+r, c.z,
|
||||||
|
c.x, c.y, c.z+r,
|
||||||
|
0xFF00FFFF, 0xFF00FFFF);
|
||||||
|
}
|
||||||
|
|
||||||
|
for(i = 0; i < colModel.numLines; i++){
|
||||||
|
verts[0] = colModel.lines[i].p0;
|
||||||
|
verts[1] = colModel.lines[i].p1;
|
||||||
|
|
||||||
|
verts[0] = mat * verts[0];
|
||||||
|
verts[1] = mat * verts[1];
|
||||||
|
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
verts[0].x, verts[0].y, verts[0].z,
|
||||||
|
verts[1].x, verts[1].y, verts[1].z,
|
||||||
|
0x00FFFFFF, 0x00FFFFFF);
|
||||||
|
}
|
||||||
|
|
||||||
|
for(i = 0; i < colModel.numBoxes; i++){
|
||||||
|
min = colModel.boxes[i].min;
|
||||||
|
max = colModel.boxes[i].max;
|
||||||
|
|
||||||
|
verts[0] = mat * CVector(min.x, min.y, min.z);
|
||||||
|
verts[1] = mat * CVector(min.x, min.y, max.z);
|
||||||
|
verts[2] = mat * CVector(min.x, max.y, min.z);
|
||||||
|
verts[3] = mat * CVector(min.x, max.y, max.z);
|
||||||
|
verts[4] = mat * CVector(max.x, min.y, min.z);
|
||||||
|
verts[5] = mat * CVector(max.x, min.y, max.z);
|
||||||
|
verts[6] = mat * CVector(max.x, max.y, min.z);
|
||||||
|
verts[7] = mat * CVector(max.x, max.y, max.z);
|
||||||
|
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
verts[0].x, verts[0].y, verts[0].z,
|
||||||
|
verts[1].x, verts[1].y, verts[1].z,
|
||||||
|
0xFFFFFFFF, 0xFFFFFFFF);
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
verts[1].x, verts[1].y, verts[1].z,
|
||||||
|
verts[3].x, verts[3].y, verts[3].z,
|
||||||
|
0xFFFFFFFF, 0xFFFFFFFF);
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
verts[3].x, verts[3].y, verts[3].z,
|
||||||
|
verts[2].x, verts[2].y, verts[2].z,
|
||||||
|
0xFFFFFFFF, 0xFFFFFFFF);
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
verts[2].x, verts[2].y, verts[2].z,
|
||||||
|
verts[0].x, verts[0].y, verts[0].z,
|
||||||
|
0xFFFFFFFF, 0xFFFFFFFF);
|
||||||
|
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
verts[4].x, verts[4].y, verts[4].z,
|
||||||
|
verts[5].x, verts[5].y, verts[5].z,
|
||||||
|
0xFFFFFFFF, 0xFFFFFFFF);
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
verts[5].x, verts[5].y, verts[5].z,
|
||||||
|
verts[7].x, verts[7].y, verts[7].z,
|
||||||
|
0xFFFFFFFF, 0xFFFFFFFF);
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
verts[7].x, verts[7].y, verts[7].z,
|
||||||
|
verts[6].x, verts[6].y, verts[6].z,
|
||||||
|
0xFFFFFFFF, 0xFFFFFFFF);
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
verts[6].x, verts[6].y, verts[6].z,
|
||||||
|
verts[4].x, verts[4].y, verts[4].z,
|
||||||
|
0xFFFFFFFF, 0xFFFFFFFF);
|
||||||
|
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
verts[0].x, verts[0].y, verts[0].z,
|
||||||
|
verts[4].x, verts[4].y, verts[4].z,
|
||||||
|
0xFFFFFFFF, 0xFFFFFFFF);
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
verts[1].x, verts[1].y, verts[1].z,
|
||||||
|
verts[5].x, verts[5].y, verts[5].z,
|
||||||
|
0xFFFFFFFF, 0xFFFFFFFF);
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
verts[2].x, verts[2].y, verts[2].z,
|
||||||
|
verts[6].x, verts[6].y, verts[6].z,
|
||||||
|
0xFFFFFFFF, 0xFFFFFFFF);
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
verts[3].x, verts[3].y, verts[3].z,
|
||||||
|
verts[7].x, verts[7].y, verts[7].z,
|
||||||
|
0xFFFFFFFF, 0xFFFFFFFF);
|
||||||
|
}
|
||||||
|
|
||||||
|
for(i = 0; i < colModel.numTriangles; i++){
|
||||||
|
colModel.GetTrianglePoint(verts[0], colModel.triangles[i].a);
|
||||||
|
colModel.GetTrianglePoint(verts[1], colModel.triangles[i].b);
|
||||||
|
colModel.GetTrianglePoint(verts[2], colModel.triangles[i].c);
|
||||||
|
verts[0] = mat * verts[0];
|
||||||
|
verts[1] = mat * verts[1];
|
||||||
|
verts[2] = mat * verts[2];
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
verts[0].x, verts[0].y, verts[0].z,
|
||||||
|
verts[1].x, verts[1].y, verts[1].z,
|
||||||
|
0x00FF00FF, 0x00FF00FF);
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
verts[0].x, verts[0].y, verts[0].z,
|
||||||
|
verts[2].x, verts[2].y, verts[2].z,
|
||||||
|
0x00FF00FF, 0x00FF00FF);
|
||||||
|
CLines::RenderLineWithClipping(
|
||||||
|
verts[1].x, verts[1].y, verts[1].z,
|
||||||
|
verts[2].x, verts[2].y, verts[2].z,
|
||||||
|
0x00FF00FF, 0x00FF00FF);
|
||||||
|
}
|
||||||
|
|
||||||
|
RwRenderStateSet(rwRENDERSTATESRCBLEND, (void*)rwBLENDSRCALPHA);
|
||||||
|
RwRenderStateSet(rwRENDERSTATEDESTBLEND, (void*)rwBLENDINVSRCALPHA);
|
||||||
|
RwRenderStateSet(rwRENDERSTATEVERTEXALPHAENABLE, (void*)FALSE);
|
||||||
|
RwRenderStateSet(rwRENDERSTATEZWRITEENABLE, (void*)TRUE);
|
||||||
|
RwRenderStateSet(rwRENDERSTATEZTESTENABLE, (void*)TRUE);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -1407,7 +1625,6 @@ CCollision::DrawColModel_Coloured(const CMatrix &mat, const CColModel &colModel,
|
|||||||
RwRenderStateSet(rwRENDERSTATESRCBLEND, (void*)rwBLENDSRCALPHA);
|
RwRenderStateSet(rwRENDERSTATESRCBLEND, (void*)rwBLENDSRCALPHA);
|
||||||
RwRenderStateSet(rwRENDERSTATEDESTBLEND, (void*)rwBLENDINVSRCALPHA);
|
RwRenderStateSet(rwRENDERSTATEDESTBLEND, (void*)rwBLENDINVSRCALPHA);
|
||||||
RwRenderStateSet(rwRENDERSTATETEXTURERASTER, nil);
|
RwRenderStateSet(rwRENDERSTATETEXTURERASTER, nil);
|
||||||
extern int gDbgSurf;
|
|
||||||
|
|
||||||
for(i = 0; i < colModel.numTriangles; i++){
|
for(i = 0; i < colModel.numTriangles; i++){
|
||||||
colModel.GetTrianglePoint(verts[0], colModel.triangles[i].a);
|
colModel.GetTrianglePoint(verts[0], colModel.triangles[i].a);
|
||||||
@ -1417,7 +1634,7 @@ extern int gDbgSurf;
|
|||||||
verts[1] = mat * verts[1];
|
verts[1] = mat * verts[1];
|
||||||
verts[2] = mat * verts[2];
|
verts[2] = mat * verts[2];
|
||||||
|
|
||||||
// TODO: surface
|
// game doesn't do this
|
||||||
r = 255;
|
r = 255;
|
||||||
g = 128;
|
g = 128;
|
||||||
b = 0;
|
b = 0;
|
||||||
@ -1457,10 +1674,15 @@ extern int gDbgSurf;
|
|||||||
b *= f;
|
b *= f;
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: make some surface types flicker?
|
if(s == SURFACE_SCAFFOLD || s == SURFACE_METAL_FENCE ||
|
||||||
//if(s != gDbgSurf) continue;
|
s == SURFACE_BOLLARD || s == SURFACE_METAL_POLE)
|
||||||
|
if(CTimer::GetFrameCounter() & 1){
|
||||||
|
r = 0;
|
||||||
|
g = 0;
|
||||||
|
b = 0;
|
||||||
|
}
|
||||||
|
|
||||||
if(s > SURFACE_32){
|
if(s > SURFACE_GATE){
|
||||||
r = CGeneral::GetRandomNumber();
|
r = CGeneral::GetRandomNumber();
|
||||||
g = CGeneral::GetRandomNumber();
|
g = CGeneral::GetRandomNumber();
|
||||||
b = CGeneral::GetRandomNumber();
|
b = CGeneral::GetRandomNumber();
|
||||||
@ -1533,8 +1755,13 @@ extern int gDbgSurf;
|
|||||||
b *= f;
|
b *= f;
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: make some surface types flicker?
|
if(s == SURFACE_SCAFFOLD || s == SURFACE_METAL_FENCE ||
|
||||||
//if(s != gDbgSurf) continue;
|
s == SURFACE_BOLLARD || s == SURFACE_METAL_POLE)
|
||||||
|
if(CTimer::GetFrameCounter() & 1){
|
||||||
|
r = 0;
|
||||||
|
g = 0;
|
||||||
|
b = 0;
|
||||||
|
}
|
||||||
|
|
||||||
RenderBuffer::StartStoring(36, 8, &iptr, &vptr);
|
RenderBuffer::StartStoring(36, 8, &iptr, &vptr);
|
||||||
RwIm3DVertexSetRGBA(&vptr[0], r, g, b, 255);
|
RwIm3DVertexSetRGBA(&vptr[0], r, g, b, 255);
|
||||||
|
@ -381,5 +381,3 @@ extern CPad *Pads; //[2]
|
|||||||
|
|
||||||
#define IsButtonJustDown(pad, btn) \
|
#define IsButtonJustDown(pad, btn) \
|
||||||
(!(pad)->OldState.btn && (pad)->NewState.btn)
|
(!(pad)->OldState.btn && (pad)->NewState.btn)
|
||||||
|
|
||||||
void LittleTest(void);
|
|
||||||
|
@ -77,6 +77,8 @@ enum eSurfaceType
|
|||||||
SURFACE_LOOSE30,
|
SURFACE_LOOSE30,
|
||||||
SURFACE_BOLLARD,
|
SURFACE_BOLLARD,
|
||||||
SURFACE_GATE,
|
SURFACE_GATE,
|
||||||
|
|
||||||
|
// These are illegal
|
||||||
SURFACE_SAND33,
|
SURFACE_SAND33,
|
||||||
SURFACE_ROAD34,
|
SURFACE_ROAD34,
|
||||||
};
|
};
|
||||||
|
@ -295,6 +295,8 @@ void
|
|||||||
RenderDebugShit(void)
|
RenderDebugShit(void)
|
||||||
{
|
{
|
||||||
// CTheScripts::RenderTheScriptDebugLines()
|
// CTheScripts::RenderTheScriptDebugLines()
|
||||||
|
if(gbShowCollisionLines)
|
||||||
|
CRenderer::RenderCollisionLines();
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -26,3 +26,5 @@ void LoadingIslandScreen(const char *levelName);
|
|||||||
CSprite2d *LoadSplash(const char *name);
|
CSprite2d *LoadSplash(const char *name);
|
||||||
char *GetLevelSplashScreen(int level);
|
char *GetLevelSplashScreen(int level);
|
||||||
char *GetRandomSplashScreen(void);
|
char *GetRandomSplashScreen(void);
|
||||||
|
|
||||||
|
void LittleTest(void);
|
||||||
|
@ -58,8 +58,6 @@ mysrand(unsigned int seed)
|
|||||||
myrand_seed = seed;
|
myrand_seed = seed;
|
||||||
}
|
}
|
||||||
|
|
||||||
int gDbgSurf;
|
|
||||||
|
|
||||||
void (*DebugMenuProcess)(void);
|
void (*DebugMenuProcess)(void);
|
||||||
void (*DebugMenuRender)(void);
|
void (*DebugMenuRender)(void);
|
||||||
static void stub(void) { }
|
static void stub(void) { }
|
||||||
@ -246,12 +244,13 @@ DebugMenuPopulate(void)
|
|||||||
|
|
||||||
DebugMenuAddVarBool8("Debug", "Show Ped Road Groups", (int8*)&gbShowPedRoadGroups, nil);
|
DebugMenuAddVarBool8("Debug", "Show Ped Road Groups", (int8*)&gbShowPedRoadGroups, nil);
|
||||||
DebugMenuAddVarBool8("Debug", "Show Car Road Groups", (int8*)&gbShowCarRoadGroups, nil);
|
DebugMenuAddVarBool8("Debug", "Show Car Road Groups", (int8*)&gbShowCarRoadGroups, nil);
|
||||||
|
DebugMenuAddVarBool8("Debug", "Show Collision Lines", (int8*)&gbShowCollisionLines, nil);
|
||||||
DebugMenuAddVarBool8("Debug", "Show Collision Polys", (int8*)&gbShowCollisionPolys, nil);
|
DebugMenuAddVarBool8("Debug", "Show Collision Polys", (int8*)&gbShowCollisionPolys, nil);
|
||||||
DebugMenuAddVarBool8("Debug", "Don't render Buildings", (int8*)&gbDontRenderBuildings, nil);
|
DebugMenuAddVarBool8("Debug", "Don't render Buildings", (int8*)&gbDontRenderBuildings, nil);
|
||||||
DebugMenuAddVarBool8("Debug", "Don't render Big Buildings", (int8*)&gbDontRenderBigBuildings, nil);
|
DebugMenuAddVarBool8("Debug", "Don't render Big Buildings", (int8*)&gbDontRenderBigBuildings, nil);
|
||||||
DebugMenuAddVarBool8("Debug", "Don't render Peds", (int8*)&gbDontRenderPeds, nil);
|
DebugMenuAddVarBool8("Debug", "Don't render Peds", (int8*)&gbDontRenderPeds, nil);
|
||||||
|
DebugMenuAddVarBool8("Debug", "Don't render Vehicles", (int8*)&gbDontRenderVehicles, nil);
|
||||||
DebugMenuAddVarBool8("Debug", "Don't render Objects", (int8*)&gbDontRenderObjects, nil);
|
DebugMenuAddVarBool8("Debug", "Don't render Objects", (int8*)&gbDontRenderObjects, nil);
|
||||||
DebugMenuAddVar("Debug", "Dbg Surface", &gDbgSurf, nil, 1, 0, 34, nil);
|
|
||||||
|
|
||||||
DebugMenuAddCmd("Debug", "Start Credits", CCredits::Start);
|
DebugMenuAddCmd("Debug", "Start Credits", CCredits::Start);
|
||||||
DebugMenuAddCmd("Debug", "Stop Credits", CCredits::Stop);
|
DebugMenuAddCmd("Debug", "Stop Credits", CCredits::Stop);
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
#include "common.h"
|
#include "common.h"
|
||||||
|
#include "main.h"
|
||||||
#include "patcher.h"
|
#include "patcher.h"
|
||||||
#include "Fluff.h"
|
#include "Fluff.h"
|
||||||
#include "Camera.h"
|
#include "Camera.h"
|
||||||
@ -7,7 +8,6 @@
|
|||||||
#include "General.h"
|
#include "General.h"
|
||||||
#include "Timer.h"
|
#include "Timer.h"
|
||||||
#include "Clock.h"
|
#include "Clock.h"
|
||||||
#include "Pad.h"
|
|
||||||
#include "Weather.h"
|
#include "Weather.h"
|
||||||
#include "Stats.h"
|
#include "Stats.h"
|
||||||
#include "math/maths.h"
|
#include "math/maths.h"
|
||||||
@ -705,7 +705,6 @@ void CTowerClock::Render()
|
|||||||
m_Position.z + Cos(angleHour) * 0.75f * m_fScale;
|
m_Position.z + Cos(angleHour) * 0.75f * m_fScale;
|
||||||
);
|
);
|
||||||
|
|
||||||
// Stupid thing that does absolutely nothing
|
|
||||||
LittleTest();
|
LittleTest();
|
||||||
|
|
||||||
// Draw lines
|
// Draw lines
|
||||||
|
74
src/render/Lines.cpp
Normal file
74
src/render/Lines.cpp
Normal file
@ -0,0 +1,74 @@
|
|||||||
|
#include "common.h"
|
||||||
|
#include "patcher.h"
|
||||||
|
#include "main.h"
|
||||||
|
#include "Lines.h"
|
||||||
|
|
||||||
|
// This is super inefficient, why split the line into segments at all?
|
||||||
|
void
|
||||||
|
CLines::RenderLineWithClipping(float x1, float y1, float z1, float x2, float y2, float z2, uint32 c1, uint32 c2)
|
||||||
|
{
|
||||||
|
static RwIm3DVertex v[2];
|
||||||
|
#ifdef THIS_IS_STUPID
|
||||||
|
int i;
|
||||||
|
float f1, f2;
|
||||||
|
float len = sqrt(sq(x1-x2) + sq(y1-y2) + sq(z1-z2));
|
||||||
|
int numsegs = len/1.5f + 1.0f;
|
||||||
|
|
||||||
|
RwRGBA col1;
|
||||||
|
col1.red = c1>>24;
|
||||||
|
col1.green = c1>>16;
|
||||||
|
col1.blue = c1>>8;
|
||||||
|
col1.alpha = c1;
|
||||||
|
RwRGBA col2;
|
||||||
|
col2.red = c2>>24;
|
||||||
|
col2.green = c2>>16;
|
||||||
|
col2.blue = c2>>8;
|
||||||
|
col2.alpha = c2;
|
||||||
|
|
||||||
|
float dx = x2 - x1;
|
||||||
|
float dy = y2 - y1;
|
||||||
|
float dz = z2 - z1;
|
||||||
|
for(i = 0; i < numsegs; i++){
|
||||||
|
f1 = (float)i/numsegs;
|
||||||
|
f2 = (float)(i+1)/numsegs;
|
||||||
|
|
||||||
|
RwIm3DVertexSetRGBA(&v[0], (int)(col1.red + (col2.red-col1.red)*f1),
|
||||||
|
(int)(col1.green + (col2.green-col1.green)*f1),
|
||||||
|
(int)(col1.blue + (col2.blue-col1.blue)*f1),
|
||||||
|
(int)(col1.alpha + (col2.alpha-col1.alpha)*f1));
|
||||||
|
RwIm3DVertexSetRGBA(&v[1], (int)(col1.red + (col2.red-col1.red)*f2),
|
||||||
|
(int)(col1.green + (col2.green-col1.green)*f2),
|
||||||
|
(int)(col1.blue + (col2.blue-col1.blue)*f2),
|
||||||
|
(int)(col1.alpha + (col2.alpha-col1.alpha)*f2));
|
||||||
|
RwIm3DVertexSetPos(&v[0], x1 + dx*f1, y1 + dy*f1, z1 + dz*f1);
|
||||||
|
RwIm3DVertexSetPos(&v[1], x1 + dx*f2, y1 + dy*f2, z1 + dz*f2);
|
||||||
|
|
||||||
|
LittleTest();
|
||||||
|
if(RwIm3DTransform(v, 2, nil, 0)){
|
||||||
|
RwIm3DRenderLine(0, 1);
|
||||||
|
RwIm3DEnd();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
RwRGBA col1;
|
||||||
|
col1.red = c1>>24;
|
||||||
|
col1.green = c1>>16;
|
||||||
|
col1.blue = c1>>8;
|
||||||
|
col1.alpha = c1;
|
||||||
|
RwRGBA col2;
|
||||||
|
col2.red = c2>>24;
|
||||||
|
col2.green = c2>>16;
|
||||||
|
col2.blue = c2>>8;
|
||||||
|
col2.alpha = c2;
|
||||||
|
|
||||||
|
RwIm3DVertexSetRGBA(&v[0], col1.red, col1.green, col1.blue, col1.alpha);
|
||||||
|
RwIm3DVertexSetRGBA(&v[1], col2.red, col2.green, col2.blue, col2.alpha);
|
||||||
|
RwIm3DVertexSetPos(&v[0], x1, y1, z1);
|
||||||
|
RwIm3DVertexSetPos(&v[1], x2, y2, z2);
|
||||||
|
LittleTest();
|
||||||
|
if(RwIm3DTransform(v, 2, nil, 0)){
|
||||||
|
RwIm3DRenderLine(0, 1);
|
||||||
|
RwIm3DEnd();
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
7
src/render/Lines.h
Normal file
7
src/render/Lines.h
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
#pragma once
|
||||||
|
|
||||||
|
class CLines
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
static void RenderLineWithClipping(float x1, float y1, float z1, float x2, float y2, float z2, uint32 c1, uint32 c2);
|
||||||
|
};
|
@ -23,11 +23,13 @@
|
|||||||
bool gbShowPedRoadGroups;
|
bool gbShowPedRoadGroups;
|
||||||
bool gbShowCarRoadGroups;
|
bool gbShowCarRoadGroups;
|
||||||
bool gbShowCollisionPolys;
|
bool gbShowCollisionPolys;
|
||||||
|
bool gbShowCollisionLines;
|
||||||
|
|
||||||
bool gbDontRenderBuildings;
|
bool gbDontRenderBuildings;
|
||||||
bool gbDontRenderBigBuildings;
|
bool gbDontRenderBigBuildings;
|
||||||
bool gbDontRenderPeds;
|
bool gbDontRenderPeds;
|
||||||
bool gbDontRenderObjects;
|
bool gbDontRenderObjects;
|
||||||
|
bool gbDontRenderVehicles;
|
||||||
|
|
||||||
struct EntityInfo
|
struct EntityInfo
|
||||||
{
|
{
|
||||||
@ -132,6 +134,10 @@ CRenderer::RenderOneNonRoad(CEntity *e)
|
|||||||
else if(e->IsObject() || e->IsDummy()){
|
else if(e->IsObject() || e->IsDummy()){
|
||||||
if(gbDontRenderObjects)
|
if(gbDontRenderObjects)
|
||||||
return;
|
return;
|
||||||
|
}else if(e->IsVehicle()){
|
||||||
|
// re3 addition
|
||||||
|
if(gbDontRenderVehicles)
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -285,6 +291,21 @@ CRenderer::RenderFadingInEntities(void)
|
|||||||
CVisibilityPlugins::RenderFadingEntities();
|
CVisibilityPlugins::RenderFadingEntities();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
CRenderer::RenderCollisionLines(void)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
|
// game doesn't draw fading in entities
|
||||||
|
// this should probably be fixed
|
||||||
|
for(i = 0; i < ms_nNoOfVisibleEntities; i++){
|
||||||
|
CEntity *e = ms_aVisibleEntityPtrs[i];
|
||||||
|
if(Abs(e->GetPosition().x - ms_vecCameraPosition.x) < 100.0f &&
|
||||||
|
Abs(e->GetPosition().y - ms_vecCameraPosition.y) < 100.0f)
|
||||||
|
CCollision::DrawColModel(e->GetMatrix(), *e->GetColModel());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
enum Visbility
|
enum Visbility
|
||||||
{
|
{
|
||||||
VIS_INVISIBLE,
|
VIS_INVISIBLE,
|
||||||
|
@ -5,11 +5,13 @@ class CEntity;
|
|||||||
extern bool gbShowPedRoadGroups;
|
extern bool gbShowPedRoadGroups;
|
||||||
extern bool gbShowCarRoadGroups;
|
extern bool gbShowCarRoadGroups;
|
||||||
extern bool gbShowCollisionPolys;
|
extern bool gbShowCollisionPolys;
|
||||||
|
extern bool gbShowCollisionLines;
|
||||||
|
|
||||||
extern bool gbDontRenderBuildings;
|
extern bool gbDontRenderBuildings;
|
||||||
extern bool gbDontRenderBigBuildings;
|
extern bool gbDontRenderBigBuildings;
|
||||||
extern bool gbDontRenderPeds;
|
extern bool gbDontRenderPeds;
|
||||||
extern bool gbDontRenderObjects;
|
extern bool gbDontRenderObjects;
|
||||||
|
extern bool gbDontRenderVehicles;
|
||||||
|
|
||||||
class CVehicle;
|
class CVehicle;
|
||||||
class CPtrList;
|
class CPtrList;
|
||||||
@ -41,6 +43,8 @@ public:
|
|||||||
static void RenderOneNonRoad(CEntity *);
|
static void RenderOneNonRoad(CEntity *);
|
||||||
static void RenderFirstPersonVehicle(void);
|
static void RenderFirstPersonVehicle(void);
|
||||||
|
|
||||||
|
static void RenderCollisionLines(void);
|
||||||
|
|
||||||
static int32 SetupEntityVisibility(CEntity *ent);
|
static int32 SetupEntityVisibility(CEntity *ent);
|
||||||
static int32 SetupBigBuildingVisibility(CEntity *ent);
|
static int32 SetupBigBuildingVisibility(CEntity *ent);
|
||||||
|
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
#include "common.h"
|
#include "common.h"
|
||||||
|
#include "main.h"
|
||||||
#include "FileMgr.h"
|
#include "FileMgr.h"
|
||||||
#include "TxdStore.h"
|
#include "TxdStore.h"
|
||||||
#include "Timer.h"
|
#include "Timer.h"
|
||||||
|
@ -34,8 +34,6 @@ RwObject *GetCurrentAtomicObjectCB(RwObject *object, void *data);
|
|||||||
|
|
||||||
bool &CAutomobile::m_sAllTaxiLights = *(bool*)0x95CD21;
|
bool &CAutomobile::m_sAllTaxiLights = *(bool*)0x95CD21;
|
||||||
|
|
||||||
WRAPPER CAutomobile* CAutomobile::ctor(int, uint8) { EAXJMP(0x52C6B0); }
|
|
||||||
|
|
||||||
CAutomobile::CAutomobile(int32 id, uint8 CreatedBy)
|
CAutomobile::CAutomobile(int32 id, uint8 CreatedBy)
|
||||||
: CVehicle(CreatedBy)
|
: CVehicle(CreatedBy)
|
||||||
{
|
{
|
||||||
@ -154,7 +152,7 @@ CAutomobile::CAutomobile(int32 id, uint8 CreatedBy)
|
|||||||
|
|
||||||
m_bombType = CARBOMB_NONE;
|
m_bombType = CARBOMB_NONE;
|
||||||
bHadDriver = false;
|
bHadDriver = false;
|
||||||
field_4DC = nil;
|
m_pBombRigger = nil;
|
||||||
|
|
||||||
if(m_nDoorLock == CARLOCK_UNLOCKED &&
|
if(m_nDoorLock == CARLOCK_UNLOCKED &&
|
||||||
(id == MI_POLICE || id == MI_ENFORCER || id == MI_RHINO))
|
(id == MI_POLICE || id == MI_ENFORCER || id == MI_RHINO))
|
||||||
@ -257,7 +255,7 @@ CAutomobile::ProcessControl(void)
|
|||||||
if(!bHadDriver && m_bombType == CARBOMB_ONIGNITIONACTIVE){
|
if(!bHadDriver && m_bombType == CARBOMB_ONIGNITIONACTIVE){
|
||||||
// If someone enters the car and there is a bomb, detonate
|
// If someone enters the car and there is a bomb, detonate
|
||||||
m_nBombTimer = 1000;
|
m_nBombTimer = 1000;
|
||||||
m_pBlowUpEntity = field_4DC;
|
m_pBlowUpEntity = m_pBombRigger;
|
||||||
if(m_pBlowUpEntity)
|
if(m_pBlowUpEntity)
|
||||||
m_pBlowUpEntity->RegisterReference((CEntity**)&m_pBlowUpEntity);
|
m_pBlowUpEntity->RegisterReference((CEntity**)&m_pBlowUpEntity);
|
||||||
DMAudio.PlayOneShot(m_audioEntityId, SOUND_BOMB_TICK, 1.0f);
|
DMAudio.PlayOneShot(m_audioEntityId, SOUND_BOMB_TICK, 1.0f);
|
||||||
@ -1476,7 +1474,7 @@ CAutomobile::VehicleDamage(float impulse, uint16 damagedPiece)
|
|||||||
FindPlayerVehicle() && FindPlayerVehicle() == m_pDamageEntity &&
|
FindPlayerVehicle() && FindPlayerVehicle() == m_pDamageEntity &&
|
||||||
m_status != STATUS_ABANDONED &&
|
m_status != STATUS_ABANDONED &&
|
||||||
FindPlayerVehicle()->m_vecMoveSpeed.Magnitude() >= m_vecMoveSpeed.Magnitude() &&
|
FindPlayerVehicle()->m_vecMoveSpeed.Magnitude() >= m_vecMoveSpeed.Magnitude() &&
|
||||||
FindPlayerVehicle()->m_vecMoveSpeed.Magnitude() > 0.2f)
|
FindPlayerVehicle()->m_vecMoveSpeed.Magnitude() > 0.1f)
|
||||||
FindPlayerPed()->SetWantedLevelNoDrop(1);
|
FindPlayerPed()->SetWantedLevelNoDrop(1);
|
||||||
|
|
||||||
if(m_status == STATUS_PLAYER && impulse > 50.0f){
|
if(m_status == STATUS_PLAYER && impulse > 50.0f){
|
||||||
|
@ -52,7 +52,7 @@ public:
|
|||||||
uint8 bNotDamagedUpsideDown : 1;
|
uint8 bNotDamagedUpsideDown : 1;
|
||||||
uint8 bMoreResistantToDamage : 1;
|
uint8 bMoreResistantToDamage : 1;
|
||||||
uint8 field_4DB;
|
uint8 field_4DB;
|
||||||
CEntity *field_4DC; // blow up entity
|
CEntity *m_pBombRigger;
|
||||||
int16 field_4E0;
|
int16 field_4E0;
|
||||||
int16 field_4E2;
|
int16 field_4E2;
|
||||||
uint32 m_nBusDoorTimerEnd;
|
uint32 m_nBusDoorTimerEnd;
|
||||||
@ -146,7 +146,5 @@ public:
|
|||||||
void ReduceHornCounter(void);
|
void ReduceHornCounter(void);
|
||||||
|
|
||||||
static void SetAllTaxiLights(bool set);
|
static void SetAllTaxiLights(bool set);
|
||||||
|
|
||||||
CAutomobile* ctor(int, uint8);
|
|
||||||
};
|
};
|
||||||
static_assert(sizeof(CAutomobile) == 0x5A8, "CAutomobile: error");
|
static_assert(sizeof(CAutomobile) == 0x5A8, "CAutomobile: error");
|
||||||
|
Loading…
x
Reference in New Issue
Block a user