Possible fix for projection hacks

git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@3427 8ced0084-cf51-0410-be5f-012b33b47a6e
This commit is contained in:
donkopunchstania 2009-06-13 17:44:14 +00:00
parent 10442c8faa
commit fcd7fa997b
2 changed files with 9 additions and 7 deletions

View File

@ -85,7 +85,7 @@ void Pos_ReadDirect()
if (three) if (three)
((float*)VertexManager::s_pCurBufferPointer)[2] = (float)(T)DataRead<T>() * posScale; ((float*)VertexManager::s_pCurBufferPointer)[2] = (float)(T)DataRead<T>() * posScale;
else else
((float*)VertexManager::s_pCurBufferPointer)[2] = 1.0f; ((float*)VertexManager::s_pCurBufferPointer)[2] = 0.0f;
LOG_VTX(); LOG_VTX();
VertexManager::s_pCurBufferPointer += 12; VertexManager::s_pCurBufferPointer += 12;
} }
@ -115,7 +115,7 @@ void LOADERDECL Pos_ReadDirect_Float2()
// No need to use floating point here. // No need to use floating point here.
((u32 *)VertexManager::s_pCurBufferPointer)[0] = DataReadU32(); ((u32 *)VertexManager::s_pCurBufferPointer)[0] = DataReadU32();
((u32 *)VertexManager::s_pCurBufferPointer)[1] = DataReadU32(); ((u32 *)VertexManager::s_pCurBufferPointer)[1] = DataReadU32();
((u32 *)VertexManager::s_pCurBufferPointer)[2] = 0x3f800000; // 1.0f ((u32 *)VertexManager::s_pCurBufferPointer)[2] = 0;
LOG_VTX(); LOG_VTX();
VertexManager::s_pCurBufferPointer += 12; VertexManager::s_pCurBufferPointer += 12;
} }
@ -130,7 +130,7 @@ inline void Pos_ReadIndex_Byte(int Index)
if (three) if (three)
((float*)VertexManager::s_pCurBufferPointer)[2] = ((float)(T)(pData[2])) * posScale; ((float*)VertexManager::s_pCurBufferPointer)[2] = ((float)(T)(pData[2])) * posScale;
else else
((float*)VertexManager::s_pCurBufferPointer)[2] = 1.0f; ((float*)VertexManager::s_pCurBufferPointer)[2] = 0.0f;
LOG_VTX(); LOG_VTX();
VertexManager::s_pCurBufferPointer += 12; VertexManager::s_pCurBufferPointer += 12;
} }
@ -144,7 +144,7 @@ inline void Pos_ReadIndex_Short(int Index)
if (three) if (three)
((float*)VertexManager::s_pCurBufferPointer)[2] = ((float)(T)Common::swap16(pData[2])) * posScale; ((float*)VertexManager::s_pCurBufferPointer)[2] = ((float)(T)Common::swap16(pData[2])) * posScale;
else else
((float*)VertexManager::s_pCurBufferPointer)[2] = 1.0f; ((float*)VertexManager::s_pCurBufferPointer)[2] = 0.0f;
LOG_VTX(); LOG_VTX();
VertexManager::s_pCurBufferPointer += 12; VertexManager::s_pCurBufferPointer += 12;
} }
@ -158,7 +158,7 @@ inline void Pos_ReadIndex_Float(int Index)
if (three) if (three)
((u32*)VertexManager::s_pCurBufferPointer)[2] = Common::swap32(pData[2]); ((u32*)VertexManager::s_pCurBufferPointer)[2] = Common::swap32(pData[2]);
else else
((float*)VertexManager::s_pCurBufferPointer)[2] = 1.0f; ((float*)VertexManager::s_pCurBufferPointer)[2] = 0.0f;
LOG_VTX(); LOG_VTX();
VertexManager::s_pCurBufferPointer += 12; VertexManager::s_pCurBufferPointer += 12;
} }

View File

@ -261,8 +261,10 @@ void VertexShaderManager::SetConstants(bool proj_hax_1,bool Hack_hack1 ,float Ha
g_fProjectionMatrix[8] = 0.0f; g_fProjectionMatrix[8] = 0.0f;
g_fProjectionMatrix[9] = 0.0f; g_fProjectionMatrix[9] = 0.0f;
g_fProjectionMatrix[10] = (Hack_hack1 ? -(Hack_value1 + xfregs.rawProjection[4]) : xfregs.rawProjection[4]); //g_fProjectionMatrix[10] = (Hack_hack1 ? -(Hack_value1 + xfregs.rawProjection[4]) : xfregs.rawProjection[4]);
g_fProjectionMatrix[11] = (Hack_hack2 ? -(Hack_value2 + xfregs.rawProjection[5]) : xfregs.rawProjection[5]) + (proj_hax_1 ? 0.1f : 0.0f); //g_fProjectionMatrix[11] = (Hack_hack2 ? -(Hack_value2 + xfregs.rawProjection[5]) : xfregs.rawProjection[5]) + (proj_hax_1 ? 0.1f : 0.0f);
g_fProjectionMatrix[10] = xfregs.rawProjection[4];
g_fProjectionMatrix[11] = xfregs.rawProjection[5];
g_fProjectionMatrix[12] = 0.0f; g_fProjectionMatrix[12] = 0.0f;
g_fProjectionMatrix[13] = 0.0f; g_fProjectionMatrix[13] = 0.0f;