mirror of
https://github.com/halpz/re3.git
synced 2025-01-25 07:00:59 +00:00
Fix IsSphereVisible calls
This commit is contained in:
parent
29d47da61e
commit
1558788df1
|
@ -4103,7 +4103,7 @@ CCamera::IsSphereVisible(const CVector ¢er, float radius, const CMatrix *mat
|
||||||
bool
|
bool
|
||||||
CCamera::IsSphereVisible(const CVector ¢er, float radius)
|
CCamera::IsSphereVisible(const CVector ¢er, float radius)
|
||||||
{
|
{
|
||||||
return IsSphereVisible(center, radius, &m_cameraMatrix);
|
return IsSphereVisible(center, radius, &GetCameraMatrix());
|
||||||
}
|
}
|
||||||
|
|
||||||
bool
|
bool
|
||||||
|
|
|
@ -6446,7 +6446,7 @@ CPed::WarpPedToNearEntityOffScreen(CEntity *warpTo)
|
||||||
|
|
||||||
if (Abs(zCorrectedPos.z - warpToPos.z) < 3.0f || Abs(zCorrectedPos.z - appropriatePos.z) < 3.0f) {
|
if (Abs(zCorrectedPos.z - warpToPos.z) < 3.0f || Abs(zCorrectedPos.z - appropriatePos.z) < 3.0f) {
|
||||||
appropriatePos.z = zCorrectedPos.z;
|
appropriatePos.z = zCorrectedPos.z;
|
||||||
if (!TheCamera.IsSphereVisible(appropriatePos, 0.6f, &TheCamera.GetCameraMatrix())
|
if (!TheCamera.IsSphereVisible(appropriatePos, 0.6f)
|
||||||
&& CWorld::GetIsLineOfSightClear(appropriatePos, warpToPos, true, true, false, true, false, false, false)
|
&& CWorld::GetIsLineOfSightClear(appropriatePos, warpToPos, true, true, false, true, false, false, false)
|
||||||
&& !CWorld::TestSphereAgainstWorld(appropriatePos, 0.6f, this, true, true, false, true, false, false)) {
|
&& !CWorld::TestSphereAgainstWorld(appropriatePos, 0.6f, this, true, true, false, true, false, false)) {
|
||||||
teleported = true;
|
teleported = true;
|
||||||
|
|
|
@ -1014,7 +1014,7 @@ CWaterLevel::RenderWater()
|
||||||
|
|
||||||
if ( fHugeSectorMaxRenderDistSqr > fHugeSectorDistToCamSqr )
|
if ( fHugeSectorMaxRenderDistSqr > fHugeSectorDistToCamSqr )
|
||||||
{
|
{
|
||||||
if ( TheCamera.IsSphereVisible(CVector(vecHugeSectorCentre.x, vecHugeSectorCentre.y, 0.0f), SectorRadius(HUGE_SECTOR_SIZE), &TheCamera.GetCameraMatrix()) )
|
if ( TheCamera.IsSphereVisible(CVector(vecHugeSectorCentre.x, vecHugeSectorCentre.y, 0.0f), SectorRadius(HUGE_SECTOR_SIZE)) )
|
||||||
{
|
{
|
||||||
#ifndef PC_WATER
|
#ifndef PC_WATER
|
||||||
WavesCalculatedThisFrame = true;
|
WavesCalculatedThisFrame = true;
|
||||||
|
@ -1088,7 +1088,7 @@ CWaterLevel::RenderWater()
|
||||||
|
|
||||||
if ( fCamDistToSector < fHugeSectorMaxRenderDistSqr )
|
if ( fCamDistToSector < fHugeSectorMaxRenderDistSqr )
|
||||||
{
|
{
|
||||||
if ( TheCamera.IsSphereVisible(CVector(vecExtraHugeSectorCentre.x, vecExtraHugeSectorCentre.y, 0.0f), SectorRadius(EXTRAHUGE_SECTOR_SIZE), &TheCamera.GetCameraMatrix()) )
|
if ( TheCamera.IsSphereVisible(CVector(vecExtraHugeSectorCentre.x, vecExtraHugeSectorCentre.y, 0.0f), SectorRadius(EXTRAHUGE_SECTOR_SIZE)) )
|
||||||
{
|
{
|
||||||
RenderOneFlatExtraHugeWaterPoly(
|
RenderOneFlatExtraHugeWaterPoly(
|
||||||
vecExtraHugeSectorCentre.x - EXTRAHUGE_SECTOR_SIZE/2,
|
vecExtraHugeSectorCentre.x - EXTRAHUGE_SECTOR_SIZE/2,
|
||||||
|
@ -1107,7 +1107,7 @@ CWaterLevel::RenderWater()
|
||||||
|
|
||||||
if ( fCamDistToSector < fHugeSectorMaxRenderDistSqr )
|
if ( fCamDistToSector < fHugeSectorMaxRenderDistSqr )
|
||||||
{
|
{
|
||||||
if ( TheCamera.IsSphereVisible(CVector(vecExtraHugeSectorCentre.x, vecExtraHugeSectorCentre.y, 0.0f), SectorRadius(EXTRAHUGE_SECTOR_SIZE), &TheCamera.GetCameraMatrix()) )
|
if ( TheCamera.IsSphereVisible(CVector(vecExtraHugeSectorCentre.x, vecExtraHugeSectorCentre.y, 0.0f), SectorRadius(EXTRAHUGE_SECTOR_SIZE)) )
|
||||||
{
|
{
|
||||||
RenderOneFlatExtraHugeWaterPoly(
|
RenderOneFlatExtraHugeWaterPoly(
|
||||||
vecExtraHugeSectorCentre.x - EXTRAHUGE_SECTOR_SIZE/2,
|
vecExtraHugeSectorCentre.x - EXTRAHUGE_SECTOR_SIZE/2,
|
||||||
|
@ -1136,7 +1136,7 @@ CWaterLevel::RenderWater()
|
||||||
|
|
||||||
if ( fCamDistToSector < fHugeSectorMaxRenderDistSqr )
|
if ( fCamDistToSector < fHugeSectorMaxRenderDistSqr )
|
||||||
{
|
{
|
||||||
if ( TheCamera.IsSphereVisible(CVector(vecExtraHugeSectorCentre.x, vecExtraHugeSectorCentre.y, 0.0f), SectorRadius(EXTRAHUGE_SECTOR_SIZE), &TheCamera.GetCameraMatrix()) )
|
if ( TheCamera.IsSphereVisible(CVector(vecExtraHugeSectorCentre.x, vecExtraHugeSectorCentre.y, 0.0f), SectorRadius(EXTRAHUGE_SECTOR_SIZE)) )
|
||||||
{
|
{
|
||||||
RenderOneFlatExtraHugeWaterPoly(
|
RenderOneFlatExtraHugeWaterPoly(
|
||||||
vecExtraHugeSectorCentre.x - EXTRAHUGE_SECTOR_SIZE/2,
|
vecExtraHugeSectorCentre.x - EXTRAHUGE_SECTOR_SIZE/2,
|
||||||
|
@ -1155,7 +1155,7 @@ CWaterLevel::RenderWater()
|
||||||
|
|
||||||
if ( fCamDistToSector < fHugeSectorMaxRenderDistSqr )
|
if ( fCamDistToSector < fHugeSectorMaxRenderDistSqr )
|
||||||
{
|
{
|
||||||
if ( TheCamera.IsSphereVisible(CVector(vecExtraHugeSectorCentre.x, vecExtraHugeSectorCentre.x, 0.0f), SectorRadius(EXTRAHUGE_SECTOR_SIZE), &TheCamera.GetCameraMatrix()) )
|
if ( TheCamera.IsSphereVisible(CVector(vecExtraHugeSectorCentre.x, vecExtraHugeSectorCentre.x, 0.0f), SectorRadius(EXTRAHUGE_SECTOR_SIZE)) )
|
||||||
{
|
{
|
||||||
RenderOneFlatExtraHugeWaterPoly(
|
RenderOneFlatExtraHugeWaterPoly(
|
||||||
vecExtraHugeSectorCentre.x - EXTRAHUGE_SECTOR_SIZE/2,
|
vecExtraHugeSectorCentre.x - EXTRAHUGE_SECTOR_SIZE/2,
|
||||||
|
@ -1287,7 +1287,7 @@ CWaterLevel::RenderTransparentWater(void)
|
||||||
|
|
||||||
if ( fHugeSectorMaxRenderDistSqr > fHugeSectorDistToCamSqr )
|
if ( fHugeSectorMaxRenderDistSqr > fHugeSectorDistToCamSqr )
|
||||||
{
|
{
|
||||||
if ( TheCamera.IsSphereVisible(CVector(vecHugeSectorCentre.x, vecHugeSectorCentre.y, 0.0f), SectorRadius(HUGE_SECTOR_SIZE), &TheCamera.GetCameraMatrix()) )
|
if ( TheCamera.IsSphereVisible(CVector(vecHugeSectorCentre.x, vecHugeSectorCentre.y, 0.0f), SectorRadius(HUGE_SECTOR_SIZE))) )
|
||||||
{
|
{
|
||||||
if ( fHugeSectorDistToCamSqr >= SQR(500.0f) )
|
if ( fHugeSectorDistToCamSqr >= SQR(500.0f) )
|
||||||
{
|
{
|
||||||
|
@ -1311,7 +1311,7 @@ CWaterLevel::RenderTransparentWater(void)
|
||||||
|
|
||||||
if ( fLargeSectorDistToCamSqr < fHugeSectorMaxRenderDistSqr )
|
if ( fLargeSectorDistToCamSqr < fHugeSectorMaxRenderDistSqr )
|
||||||
{
|
{
|
||||||
if ( TheCamera.IsSphereVisible(CVector(vecLargeSectorCentre.x, vecLargeSectorCentre.y, 0.0f), SectorRadius(LARGE_SECTOR_SIZE), &TheCamera.GetCameraMatrix()) )
|
if ( TheCamera.IsSphereVisible(CVector(vecLargeSectorCentre.x, vecLargeSectorCentre.y, 0.0f), SectorRadius(LARGE_SECTOR_SIZE)) )
|
||||||
{
|
{
|
||||||
// Render four small(32x32) sectors, or one large(64x64).
|
// Render four small(32x32) sectors, or one large(64x64).
|
||||||
|
|
||||||
|
@ -3198,7 +3198,7 @@ CWaterLevel::HandleBeachToysStuff(void)
|
||||||
vecPos.x += (fCos - fSin) * fAngle;
|
vecPos.x += (fCos - fSin) * fAngle;
|
||||||
vecPos.y += (fSin + fCos) * fAngle;
|
vecPos.y += (fSin + fCos) * fAngle;
|
||||||
|
|
||||||
if ( TheCamera.IsSphereVisible(vecPos, 1.0f, &TheCamera.GetCameraMatrix()) )
|
if ( TheCamera.IsSphereVisible(vecPos, 1.0f) )
|
||||||
{
|
{
|
||||||
float fWaterLevel;
|
float fWaterLevel;
|
||||||
|
|
||||||
|
@ -3242,7 +3242,7 @@ CWaterLevel::HandleBeachToysStuff(void)
|
||||||
vecPos.x += (fCos - fSin) * fAngle;
|
vecPos.x += (fCos - fSin) * fAngle;
|
||||||
vecPos.y += (fSin + fCos) * fAngle;
|
vecPos.y += (fSin + fCos) * fAngle;
|
||||||
|
|
||||||
if ( TheCamera.IsSphereVisible(vecPos, 2.0f, &TheCamera.GetCameraMatrix()) )
|
if ( TheCamera.IsSphereVisible(vecPos, 2.0f) )
|
||||||
{
|
{
|
||||||
float fWaterLevel;
|
float fWaterLevel;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue