mirror of
https://github.com/MaSzyna-EU07/maszyna.git
synced 2026-03-22 15:05:03 +01:00
framerate-independent cab camera shake, minor bug fixes
This commit is contained in:
@@ -2441,8 +2441,8 @@ bool TController::IncSpeed()
|
||||
if (tsGuardSignal->GetStatus() & DSBSTATUS_PLAYING) // jeśli gada, to nie jedziemy
|
||||
return false;
|
||||
bool OK = true;
|
||||
if ((iDrivigFlags & moveDoorOpened)
|
||||
&&(mvOccupied->Vel > 0.1)) // added velocity threshold to prevent door shuffle on stop
|
||||
if ( ( iDrivigFlags & moveDoorOpened )
|
||||
&& ( VelDesired > 0.0 ) ) // to prevent door shuffle on stop
|
||||
Doors(false); // zamykanie drzwi - tutaj wykonuje tylko AI (zmienia fActionTime)
|
||||
if (fActionTime < 0.0) // gdy jest nakaz poczekać z jazdą, to nie ruszać
|
||||
return false;
|
||||
|
||||
7
EU07.cpp
7
EU07.cpp
@@ -81,9 +81,12 @@ void key_callback( GLFWwindow *window, int key, int scancode, int action, int mo
|
||||
switch( key )
|
||||
{
|
||||
case GLFW_KEY_ESCAPE: {
|
||||
//[Esc] pauzuje tylko bez Debugmode
|
||||
if( DebugModeFlag )
|
||||
|
||||
if( ( DebugModeFlag ) //[Esc] pauzuje tylko bez Debugmode
|
||||
&& ( Global::iPause == 0 ) ) { // but unpausing should work always
|
||||
|
||||
break;
|
||||
}
|
||||
|
||||
if( Global::iPause & 1 ) // jeśli pauza startowa
|
||||
Global::iPause &= ~1; // odpauzowanie, gdy po wczytaniu miało nie startować
|
||||
|
||||
@@ -1977,7 +1977,8 @@ TGroundNode * TGround::AddGroundNode(cParser *parser)
|
||||
if( tmp->DynamicObject->MoverParameters->LightPowerSource.SourceType != TPowerSource::NotDefined ) {
|
||||
// if the vehicle has defined light source, it can (potentially) emit light, so add it to the light array
|
||||
*/
|
||||
if( tmp->DynamicObject->MoverParameters->SecuritySystem.SystemType != 0 ) {
|
||||
if( ( tmp != nullptr )
|
||||
&& ( tmp->DynamicObject->MoverParameters->SecuritySystem.SystemType != 0 ) ) {
|
||||
// we check for presence of security system, as a way to determine whether the vehicle is a controllable engine
|
||||
// NOTE: this isn't 100% precise, e.g. middle EZT module comes with security system, while it has no lights
|
||||
m_lights.insert( tmp->DynamicObject );
|
||||
@@ -4009,6 +4010,7 @@ bool TGround::EventConditon(TEvent *e)
|
||||
{ // sprawdzenie spelnienia warunków dla eventu
|
||||
if (e->iFlags <= update_only)
|
||||
return true; // bezwarunkowo
|
||||
|
||||
if (e->iFlags & conditional_trackoccupied)
|
||||
return (!e->Params[9].asTrack->IsEmpty());
|
||||
else if (e->iFlags & conditional_trackfree)
|
||||
@@ -4022,6 +4024,11 @@ bool TGround::EventConditon(TEvent *e)
|
||||
}
|
||||
else if (e->iFlags & conditional_memcompare)
|
||||
{ // porównanie wartości
|
||||
if( nullptr == e->Params[9].asMemCell ) {
|
||||
|
||||
ErrorLog( "Event " + e->asName + " trying conditional_memcompare with nonexistent memcell" );
|
||||
return true; // though this is technically error, we report success to maintain backward compatibility
|
||||
}
|
||||
if (tmpEvent->Params[9].asMemCell->Compare(e->Params[10].asText, e->Params[11].asdouble,
|
||||
e->Params[12].asdouble, e->iFlags))
|
||||
{ //logowanie spełnionych warunków
|
||||
|
||||
151
Train.cpp
151
Train.cpp
@@ -2384,7 +2384,7 @@ if
|
||||
{
|
||||
// McZapkie: poruszanie sie po kabinie, w updatemechpos zawarte sa wiezy
|
||||
|
||||
auto step = 1.5f;
|
||||
auto step = 1.0f;
|
||||
auto const camerayaw = Global::pCamera->Yaw;
|
||||
Math3D::vector3 direction( 0.0f, 0.0f, step );
|
||||
direction.RotateY( camerayaw );
|
||||
@@ -2501,6 +2501,7 @@ void TTrain::OnKeyUp(int cKey)
|
||||
}
|
||||
};
|
||||
|
||||
// cab movement update, fixed step part
|
||||
void TTrain::UpdateMechPosition(double dt)
|
||||
{ // Ra: mechanik powinien być
|
||||
// telepany niezależnie od pozycji
|
||||
@@ -2514,123 +2515,111 @@ void TTrain::UpdateMechPosition(double dt)
|
||||
// - na postoju horyzont prosto, kabina skosem
|
||||
// - przy szybkiej jeździe kabina prosto, horyzont pochylony
|
||||
|
||||
vector3 pNewMechPosition;
|
||||
Math3D::vector3 shake;
|
||||
// McZapkie: najpierw policzę pozycję w/m kabiny
|
||||
|
||||
// ABu: rzucamy kabina tylko przy duzym FPS!
|
||||
// Mala histereza, zeby bez przerwy nie przelaczalo przy FPS~17
|
||||
// Granice mozna ustalic doswiadczalnie. Ja proponuje 14:20
|
||||
double const iVel = std::min(DynamicObject->GetVelocity(), 150.0);
|
||||
double const iVel = std::min( DynamicObject->GetVelocity(), 150.0 );
|
||||
|
||||
if (!Global::iSlowMotion // musi być pełna prędkość
|
||||
&& (pMechOffset.y < 4.0)) // Ra 15-01: przy oglądaniu pantografu bujanie przeszkadza
|
||||
if( !Global::iSlowMotion // musi być pełna prędkość
|
||||
&& ( pMechOffset.y < 4.0 ) ) // Ra 15-01: przy oglądaniu pantografu bujanie przeszkadza
|
||||
{
|
||||
if( iVel > 0.0 ) {
|
||||
if( iVel > 0.5 ) {
|
||||
// acceleration-driven base shake
|
||||
shake += 1.25 * MechSpring.ComputateForces(
|
||||
vector3(
|
||||
-mvControlled->AccN * dt * 5.0, // highlight side sway
|
||||
mvControlled->AccV * dt,
|
||||
-mvControlled->AccS * dt * 1.25 ), // accent acceleration/deceleration
|
||||
-mvControlled->AccN * dt * 5.0, // highlight side sway
|
||||
mvControlled->AccV * dt,
|
||||
-mvControlled->AccS * dt * 1.25 ), // accent acceleration/deceleration
|
||||
pMechShake );
|
||||
|
||||
if( Random( iVel ) > 25.0 ) {
|
||||
// extra shake at increased velocity
|
||||
shake += MechSpring.ComputateForces(
|
||||
vector3(
|
||||
( Random( iVel * 2 ) - iVel ) / ( ( iVel * 2 ) * 4 ) * fMechSpringX,
|
||||
( Random( iVel * 2 ) - iVel ) / ( ( iVel * 2 ) * 4 ) * fMechSpringY,
|
||||
( Random( iVel * 2 ) - iVel ) / ( ( iVel * 2 ) * 4 ) * fMechSpringZ ),
|
||||
( Random( iVel * 2 ) - iVel ) / ( ( iVel * 2 ) * 4 ) * fMechSpringX,
|
||||
( Random( iVel * 2 ) - iVel ) / ( ( iVel * 2 ) * 4 ) * fMechSpringY,
|
||||
( Random( iVel * 2 ) - iVel ) / ( ( iVel * 2 ) * 4 ) * fMechSpringZ )
|
||||
* 1.25,
|
||||
pMechShake );
|
||||
// * (( 200 - DynamicObject->MyTrack->iQualityFlag ) * 0.0075 ); // scale to 75-150% based on track quality
|
||||
// * (( 200 - DynamicObject->MyTrack->iQualityFlag ) * 0.0075 ); // scale to 75-150% based on track quality
|
||||
}
|
||||
// shake *= 1.25;
|
||||
// shake *= 0.85;
|
||||
}
|
||||
vMechVelocity -= (shake + vMechVelocity * 100) * (fMechSpringX + fMechSpringY + fMechSpringZ) / (200);
|
||||
// vMechVelocity -= vMechVelocity * iVel * dt;
|
||||
// shake *= 0.95 * dt; // shake damping
|
||||
vMechVelocity -= ( shake + vMechVelocity * 100 ) * ( fMechSpringX + fMechSpringY + fMechSpringZ ) / ( 200 );
|
||||
// shake *= 0.95 * dt; // shake damping
|
||||
|
||||
// McZapkie:
|
||||
pMechShake += vMechVelocity * dt;
|
||||
// Ra 2015-01: dotychczasowe rzucanie
|
||||
pMechOffset += vMechMovement * dt;
|
||||
if ((pMechShake.y > fMechMaxSpring) || (pMechShake.y < -fMechMaxSpring))
|
||||
if( ( pMechShake.y > fMechMaxSpring ) || ( pMechShake.y < -fMechMaxSpring ) )
|
||||
vMechVelocity.y = -vMechVelocity.y;
|
||||
// ABu011104: 5*pMechShake.y, zeby ladnie pudlem rzucalo :)
|
||||
pNewMechPosition = pMechOffset + vector3(1.5 * pMechShake.x, 2.0 * pMechShake.y, 1.5 * pMechShake.z);
|
||||
// vMechMovement = 0.5 * vMechMovement;
|
||||
pMechPosition = pMechOffset + vector3( 1.5 * pMechShake.x, 2.0 * pMechShake.y, 1.5 * pMechShake.z );
|
||||
vMechMovement = 0.5 * vMechMovement;
|
||||
}
|
||||
else
|
||||
{ // hamowanie rzucania przy spadku FPS
|
||||
pMechShake -= pMechShake * std::min(dt, 1.0); // po tym chyba potrafią zostać jakieś ułamki, które powodują zjazd
|
||||
else { // hamowanie rzucania przy spadku FPS
|
||||
pMechShake -= pMechShake * std::min( dt, 1.0 ); // po tym chyba potrafią zostać jakieś ułamki, które powodują zjazd
|
||||
pMechOffset += vMechMovement * dt;
|
||||
vMechVelocity.y -= vMechVelocity.y * 50.0 * dt;
|
||||
pNewMechPosition = pMechOffset + vector3(pMechShake.x, 5 * pMechShake.y, pMechShake.z);
|
||||
// vMechMovement = 0.5 * vMechMovement;
|
||||
vMechVelocity.y = 0.5 * vMechVelocity.y;
|
||||
pMechPosition = pMechOffset + vector3( pMechShake.x, 5 * pMechShake.y, pMechShake.z );
|
||||
vMechMovement = 0.5 * vMechMovement;
|
||||
}
|
||||
// numer kabiny (-1: kabina B)
|
||||
if (DynamicObject->Mechanik) // może nie być?
|
||||
if (DynamicObject->Mechanik->AIControllFlag) // jeśli prowadzi AI
|
||||
if( DynamicObject->Mechanik ) // może nie być?
|
||||
if( DynamicObject->Mechanik->AIControllFlag ) // jeśli prowadzi AI
|
||||
{ // Ra: przesiadka, jeśli AI zmieniło kabinę (a człon?)...
|
||||
if (iCabn != (DynamicObject->MoverParameters->ActiveCab == -1 ?
|
||||
2 :
|
||||
DynamicObject->MoverParameters->ActiveCab))
|
||||
InitializeCab(DynamicObject->MoverParameters->ActiveCab,
|
||||
DynamicObject->asBaseDir + DynamicObject->MoverParameters->TypeName +
|
||||
".mmd");
|
||||
if( iCabn != ( DynamicObject->MoverParameters->ActiveCab == -1 ?
|
||||
2 :
|
||||
DynamicObject->MoverParameters->ActiveCab ) )
|
||||
InitializeCab( DynamicObject->MoverParameters->ActiveCab,
|
||||
DynamicObject->asBaseDir + DynamicObject->MoverParameters->TypeName +
|
||||
".mmd" );
|
||||
}
|
||||
iCabn = (DynamicObject->MoverParameters->ActiveCab == -1 ?
|
||||
2 :
|
||||
DynamicObject->MoverParameters->ActiveCab);
|
||||
if (!DebugModeFlag)
|
||||
{ // sprawdzaj więzy //Ra: nie tu!
|
||||
if (pNewMechPosition.x < Cabine[iCabn].CabPos1.x)
|
||||
pNewMechPosition.x = Cabine[iCabn].CabPos1.x;
|
||||
if (pNewMechPosition.x > Cabine[iCabn].CabPos2.x)
|
||||
pNewMechPosition.x = Cabine[iCabn].CabPos2.x;
|
||||
if (pNewMechPosition.z < Cabine[iCabn].CabPos1.z)
|
||||
pNewMechPosition.z = Cabine[iCabn].CabPos1.z;
|
||||
if (pNewMechPosition.z > Cabine[iCabn].CabPos2.z)
|
||||
pNewMechPosition.z = Cabine[iCabn].CabPos2.z;
|
||||
if (pNewMechPosition.y > Cabine[iCabn].CabPos1.y + 1.8)
|
||||
pNewMechPosition.y = Cabine[iCabn].CabPos1.y + 1.8;
|
||||
if (pNewMechPosition.y < Cabine[iCabn].CabPos1.y + 0.5)
|
||||
pNewMechPosition.y = Cabine[iCabn].CabPos2.y + 0.5;
|
||||
iCabn = ( DynamicObject->MoverParameters->ActiveCab == -1 ?
|
||||
2 :
|
||||
DynamicObject->MoverParameters->ActiveCab );
|
||||
if( !DebugModeFlag ) { // sprawdzaj więzy //Ra: nie tu!
|
||||
if( pMechPosition.x < Cabine[ iCabn ].CabPos1.x )
|
||||
pMechPosition.x = Cabine[ iCabn ].CabPos1.x;
|
||||
if( pMechPosition.x > Cabine[ iCabn ].CabPos2.x )
|
||||
pMechPosition.x = Cabine[ iCabn ].CabPos2.x;
|
||||
if( pMechPosition.z < Cabine[ iCabn ].CabPos1.z )
|
||||
pMechPosition.z = Cabine[ iCabn ].CabPos1.z;
|
||||
if( pMechPosition.z > Cabine[ iCabn ].CabPos2.z )
|
||||
pMechPosition.z = Cabine[ iCabn ].CabPos2.z;
|
||||
if( pMechPosition.y > Cabine[ iCabn ].CabPos1.y + 1.8 )
|
||||
pMechPosition.y = Cabine[ iCabn ].CabPos1.y + 1.8;
|
||||
if( pMechPosition.y < Cabine[ iCabn ].CabPos1.y + 0.5 )
|
||||
pMechPosition.y = Cabine[ iCabn ].CabPos2.y + 0.5;
|
||||
|
||||
if (pMechOffset.x < Cabine[iCabn].CabPos1.x)
|
||||
pMechOffset.x = Cabine[iCabn].CabPos1.x;
|
||||
if (pMechOffset.x > Cabine[iCabn].CabPos2.x)
|
||||
pMechOffset.x = Cabine[iCabn].CabPos2.x;
|
||||
if (pMechOffset.z < Cabine[iCabn].CabPos1.z)
|
||||
pMechOffset.z = Cabine[iCabn].CabPos1.z;
|
||||
if (pMechOffset.z > Cabine[iCabn].CabPos2.z)
|
||||
pMechOffset.z = Cabine[iCabn].CabPos2.z;
|
||||
if (pMechOffset.y > Cabine[iCabn].CabPos1.y + 1.8)
|
||||
pMechOffset.y = Cabine[iCabn].CabPos1.y + 1.8;
|
||||
if (pMechOffset.y < Cabine[iCabn].CabPos1.y + 0.5)
|
||||
pMechOffset.y = Cabine[iCabn].CabPos2.y + 0.5;
|
||||
if( pMechOffset.x < Cabine[ iCabn ].CabPos1.x )
|
||||
pMechOffset.x = Cabine[ iCabn ].CabPos1.x;
|
||||
if( pMechOffset.x > Cabine[ iCabn ].CabPos2.x )
|
||||
pMechOffset.x = Cabine[ iCabn ].CabPos2.x;
|
||||
if( pMechOffset.z < Cabine[ iCabn ].CabPos1.z )
|
||||
pMechOffset.z = Cabine[ iCabn ].CabPos1.z;
|
||||
if( pMechOffset.z > Cabine[ iCabn ].CabPos2.z )
|
||||
pMechOffset.z = Cabine[ iCabn ].CabPos2.z;
|
||||
if( pMechOffset.y > Cabine[ iCabn ].CabPos1.y + 1.8 )
|
||||
pMechOffset.y = Cabine[ iCabn ].CabPos1.y + 1.8;
|
||||
if( pMechOffset.y < Cabine[ iCabn ].CabPos1.y + 0.5 )
|
||||
pMechOffset.y = Cabine[ iCabn ].CabPos2.y + 0.5;
|
||||
}
|
||||
pMechPosition = DynamicObject->mMatrix *
|
||||
pNewMechPosition; // położenie względem środka pojazdu w układzie scenerii
|
||||
pMechPosition += DynamicObject->GetPosition();
|
||||
|
||||
// framerate-independent speed reduction that doesn't break at high framerates...
|
||||
Math3D::vector3 movementslowdown = vMechMovement * 35 * dt;
|
||||
if( movementslowdown.LengthSquared() >= vMechMovement.LengthSquared() ) {
|
||||
// if the reduction vector exceeds speed movement we're running at low fps,
|
||||
// fallback on the old behaviour
|
||||
vMechMovement *= 0.5;
|
||||
}
|
||||
else {
|
||||
vMechMovement -= movementslowdown;
|
||||
if( vMechMovement.LengthSquared() < 0.01 ) {
|
||||
vMechMovement = Math3D::vector3();
|
||||
}
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
// returns position of the mechanic in the scene coordinates
|
||||
vector3
|
||||
TTrain::GetWorldMechPosition() {
|
||||
|
||||
vector3 position = DynamicObject->mMatrix *pMechPosition; // położenie względem środka pojazdu w układzie scenerii
|
||||
position += DynamicObject->GetPosition();
|
||||
return position;
|
||||
}
|
||||
|
||||
bool TTrain::Update( double const Deltatime )
|
||||
{
|
||||
DWORD stat;
|
||||
|
||||
1
Train.h
1
Train.h
@@ -94,6 +94,7 @@ class TTrain
|
||||
return DynamicObject->VectorUp();
|
||||
};
|
||||
void UpdateMechPosition(double dt);
|
||||
vector3 GetWorldMechPosition();
|
||||
bool Update( double const Deltatime );
|
||||
bool m_updated = false;
|
||||
void MechStop();
|
||||
|
||||
172
World.cpp
172
World.cpp
@@ -359,8 +359,6 @@ bool TWorld::Init( GLFWwindow *w ) {
|
||||
WriteLog("Display Lists font used."); //+AnsiString(glGetError())
|
||||
WriteLog("Font init OK"); //+AnsiString(glGetError())
|
||||
|
||||
Timer::ResetTimers();
|
||||
|
||||
glColor4f(1.0f, 3.0f, 3.0f, 0.0f);
|
||||
// SwapBuffers(hDC); // Swap Buffers (Double Buffering)
|
||||
// glClear(GL_COLOR_BUFFER_BIT);
|
||||
@@ -552,7 +550,6 @@ bool TWorld::Init( GLFWwindow *w ) {
|
||||
else
|
||||
light = GfxRenderer.GetTextureId( "smuga2.tga", szTexturePath );
|
||||
// Camera.Reset();
|
||||
Timer::ResetTimers();
|
||||
WriteLog( "Load time: " +
|
||||
std::to_string( std::chrono::duration_cast<std::chrono::seconds>(( std::chrono::system_clock::now() - timestart )).count() )
|
||||
+ " seconds");
|
||||
@@ -560,6 +557,9 @@ bool TWorld::Init( GLFWwindow *w ) {
|
||||
if (Train)
|
||||
if (Train->Dynamic()->Mechanik)
|
||||
Train->Dynamic()->Mechanik->TakeControl(true);
|
||||
|
||||
Timer::ResetTimers();
|
||||
|
||||
return true;
|
||||
};
|
||||
|
||||
@@ -719,7 +719,7 @@ void TWorld::OnKeyDown(int cKey)
|
||||
}
|
||||
if( Global::iTextMode == GLFW_KEY_F10 ) // wyświetlone napisy klawiszem F10
|
||||
{ // i potwierdzenie
|
||||
if( cKey == 'Y' ) {
|
||||
if( cKey == GLFW_KEY_Y ) {
|
||||
// flaga wyjścia z programu
|
||||
::PostQuitMessage( 0 );
|
||||
// Global::iTextMode = -1;
|
||||
@@ -730,9 +730,9 @@ void TWorld::OnKeyDown(int cKey)
|
||||
{ // tryb konfiguracji debugmode (przestawianie kamery już wyłączone
|
||||
if (!Global::shiftState) // bez [Shift]
|
||||
{
|
||||
if (cKey == '1')
|
||||
if (cKey == GLFW_KEY_1)
|
||||
Global::iWriteLogEnabled ^= 1; // włącz/wyłącz logowanie do pliku
|
||||
else if (cKey == '2')
|
||||
else if (cKey == GLFW_KEY_2)
|
||||
{ // włącz/wyłącz okno konsoli
|
||||
Global::iWriteLogEnabled ^= 2;
|
||||
if ((Global::iWriteLogEnabled & 2) == 0) // nie było okienka
|
||||
@@ -745,7 +745,7 @@ void TWorld::OnKeyDown(int cKey)
|
||||
// else if (cKey=='3') Global::iWriteLogEnabled^=4; //wypisywanie nazw torów
|
||||
}
|
||||
}
|
||||
else if (cKey == 3) //[Ctrl]+[Break]
|
||||
else if( cKey == GLFW_KEY_3 ) //[Ctrl]+[Break]
|
||||
{ // hamowanie wszystkich pojazdów w okolicy
|
||||
if (Controlled->MoverParameters->Radio)
|
||||
Ground.RadioStop(Camera.Pos);
|
||||
@@ -753,7 +753,7 @@ void TWorld::OnKeyDown(int cKey)
|
||||
else if (!Global::iPause) //||(cKey==VK_F4)) //podczas pauzy sterownaie nie działa, F4 tak
|
||||
if (Train)
|
||||
if (Controlled)
|
||||
if ((Controlled->Controller == Humandriver) ? true : DebugModeFlag || (cKey == 'Q'))
|
||||
if ((Controlled->Controller == Humandriver) ? true : DebugModeFlag || (cKey == GLFW_KEY_Q))
|
||||
Train->OnKeyDown(cKey); // przekazanie klawisza do kabiny
|
||||
if (FreeFlyModeFlag) // aby nie odluźniało wagonu za lokomotywą
|
||||
{ // operacje wykonywane na dowolnym pojeździe, przeniesione tu z kabiny
|
||||
@@ -971,25 +971,19 @@ void TWorld::FollowView(bool wycisz)
|
||||
}
|
||||
else if (Train)
|
||||
{ // korekcja ustawienia w kabinie - OK
|
||||
vector3 camStara =
|
||||
Camera.Pos; // przestawianie kamery jest bez sensu: do przerobienia na potem
|
||||
vector3 camStara = Camera.Pos; // przestawianie kamery jest bez sensu: do przerobienia na potem
|
||||
// Ra: czy to tu jest potrzebne, bo przelicza się kawałek dalej?
|
||||
Camera.Pos = Train->pMechPosition; // Train.GetPosition1();
|
||||
Camera.Roll = atan(Train->pMechShake.x * Train->fMechRoll); // hustanie kamery na boki
|
||||
Camera.Pitch -=
|
||||
atan(Train->vMechVelocity.z * Train->fMechPitch); // hustanie kamery przod tyl
|
||||
Camera.Roll = std::atan(Train->pMechShake.x * Train->fMechRoll); // hustanie kamery na boki
|
||||
Camera.Pitch -= 0.5 * std::atan(Train->vMechVelocity.z * Train->fMechPitch); // hustanie kamery przod tyl
|
||||
if (Train->Dynamic()->MoverParameters->ActiveCab == 0)
|
||||
Camera.LookAt = Train->pMechPosition + Train->GetDirection();
|
||||
Camera.LookAt = Train->pMechPosition + Train->GetDirection() * 5.0;
|
||||
else // patrz w strone wlasciwej kabiny
|
||||
Camera.LookAt =
|
||||
Train->pMechPosition +
|
||||
Train->GetDirection() * Train->Dynamic()->MoverParameters->ActiveCab;
|
||||
Camera.LookAt = Train->pMechPosition + Train->GetDirection() * 5.0 * Train->Dynamic()->MoverParameters->ActiveCab;
|
||||
Train->pMechOffset.x = Train->pMechSittingPosition.x;
|
||||
Train->pMechOffset.y = Train->pMechSittingPosition.y;
|
||||
Train->pMechOffset.z = Train->pMechSittingPosition.z;
|
||||
Global::SetCameraPosition(
|
||||
Train->Dynamic()
|
||||
->GetPosition()); // tu ustawić nową, bo od niej liczą się odległości
|
||||
Global::SetCameraPosition( Train->Dynamic() ->GetPosition()); // tu ustawić nową, bo od niej liczą się odległości
|
||||
if (wycisz) // trzymanie prawego w kabinie daje marny efekt
|
||||
Ground.Silence(camStara); // wyciszenie dźwięków z poprzedniej pozycji
|
||||
}
|
||||
@@ -1105,8 +1099,8 @@ bool TWorld::Update()
|
||||
}
|
||||
*/
|
||||
/*
|
||||
// NOTE: until we have no physics state interpolation during render, we need to rely on the old code
|
||||
// doing fixed step calculations but flexible step render results in ugly mini jitter
|
||||
// NOTE: until we have no physics state interpolation during render, we need to rely on the old code,
|
||||
// as doing fixed step calculations but flexible step render results in ugly mini jitter
|
||||
// core routines (physics)
|
||||
int updatecount = 0;
|
||||
while( ( m_primaryupdateaccumulator >= m_primaryupdaterate )
|
||||
@@ -1150,7 +1144,12 @@ bool TWorld::Update()
|
||||
iPause = Global::iPause;
|
||||
}
|
||||
|
||||
// TODO: add fixed step part of the camera update here
|
||||
// fixed step part of the camera update
|
||||
if( (Train != nullptr)
|
||||
&& (Camera.Type == tp_Follow )) {
|
||||
// jeśli jazda w kabinie, przeliczyć trzeba parametry kamery
|
||||
Train->UpdateMechPosition( m_secondaryupdaterate / Global::fTimeSpeed ); // ograniczyć telepanie po przyspieszeniu
|
||||
}
|
||||
|
||||
m_secondaryupdateaccumulator -= m_secondaryupdaterate; // these should be inexpensive enough we have no cap
|
||||
}
|
||||
@@ -1173,9 +1172,9 @@ bool TWorld::Update()
|
||||
|
||||
// fixed step render time routines
|
||||
fTime50Hz += dt; // w pauzie też trzeba zliczać czas, bo przy dużym FPS będzie problem z odczytem ramek
|
||||
if( fTime50Hz >= 0.2 ) {
|
||||
while( fTime50Hz >= 1.0 / 50.0 ) {
|
||||
Console::Update(); // to i tak trzeba wywoływać
|
||||
fTime50Hz -= 0.2;
|
||||
fTime50Hz -= 1.0 / 50.0;
|
||||
}
|
||||
|
||||
// variable step render time routines
|
||||
@@ -1253,77 +1252,70 @@ TWorld::Update_Camera( double const Deltatime ) {
|
||||
}
|
||||
*/
|
||||
Camera.Update(); // uwzględnienie ruchu wywołanego klawiszami
|
||||
|
||||
/*
|
||||
if( Camera.Type == tp_Follow ) {
|
||||
if( Train ) { // jeśli jazda w kabinie, przeliczyć trzeba parametry kamery
|
||||
Train->UpdateMechPosition( Deltatime /
|
||||
Global::fTimeSpeed ); // ograniczyć telepanie po przyspieszeniu
|
||||
vector3 tempangle;
|
||||
double modelrotate;
|
||||
tempangle =
|
||||
Controlled->VectorFront() * ( Controlled->MoverParameters->ActiveCab == -1 ? -1 : 1 );
|
||||
modelrotate = atan2( -tempangle.x, tempangle.z );
|
||||
if( Global::ctrlState ? ( Console::Pressed( Global::Keys[ k_MechLeft ] ) ||
|
||||
Console::Pressed( Global::Keys[ k_MechRight ] ) ) :
|
||||
false ) { // jeśli lusterko lewe albo prawe (bez rzucania na razie)
|
||||
bool lr = Console::Pressed( Global::Keys[ k_MechLeft ] );
|
||||
// Camera.Yaw powinno być wyzerowane, aby po powrocie patrzeć do przodu
|
||||
Camera.Pos =
|
||||
Controlled->GetPosition() + Train->MirrorPosition( lr ); // pozycja lusterka
|
||||
Camera.Yaw = 0; // odchylenie na bok od Camera.LookAt
|
||||
if( Train->Dynamic()->MoverParameters->ActiveCab == 0 )
|
||||
Camera.LookAt = Camera.Pos - Train->GetDirection(); // gdy w korytarzu
|
||||
else if( Global::shiftState ) { // patrzenie w bok przez szybę
|
||||
Camera.LookAt = Camera.Pos -
|
||||
( lr ? -1 : 1 ) * Train->Dynamic()->VectorLeft() *
|
||||
Train->Dynamic()->MoverParameters->ActiveCab;
|
||||
Global::SetCameraRotation( -modelrotate );
|
||||
}
|
||||
else { // patrzenie w kierunku osi pojazdu, z uwzględnieniem kabiny - jakby z lusterka,
|
||||
// ale bez odbicia
|
||||
Camera.LookAt = Camera.Pos -
|
||||
Train->GetDirection() *
|
||||
Train->Dynamic()->MoverParameters->ActiveCab; //-1 albo 1
|
||||
Global::SetCameraRotation( M_PI -
|
||||
modelrotate ); // tu już trzeba uwzględnić lusterka
|
||||
}
|
||||
Camera.Roll =
|
||||
atan( Train->pMechShake.x * Train->fMechRoll ); // hustanie kamery na boki
|
||||
Camera.Pitch =
|
||||
atan( Train->vMechVelocity.z * Train->fMechPitch ); // hustanie kamery przod tyl
|
||||
Camera.vUp = Controlled->VectorUp();
|
||||
}
|
||||
else { // patrzenie standardowe
|
||||
Camera.Pos = Train->pMechPosition; // Train.GetPosition1();
|
||||
if( !Global::iPause ) { // podczas pauzy nie przeliczać kątów przypadkowymi wartościami
|
||||
Camera.Roll =
|
||||
atan( Train->pMechShake.x * Train->fMechRoll ); // hustanie kamery na boki
|
||||
Camera.Pitch -= atan( Train->vMechVelocity.z *
|
||||
Train->fMechPitch ); // hustanie kamery przod tyl //Ra: tu
|
||||
// jest uciekanie kamery w górę!!!
|
||||
}
|
||||
// ABu011104: rzucanie pudlem
|
||||
vector3 temp;
|
||||
if( abs( Train->pMechShake.y ) < 0.25 )
|
||||
temp = vector3( 0, 0, 6 * Train->pMechShake.y );
|
||||
else if( ( Train->pMechShake.y ) > 0 )
|
||||
temp = vector3( 0, 0, 6 * 0.25 );
|
||||
else
|
||||
temp = vector3( 0, 0, -6 * 0.25 );
|
||||
if( Controlled )
|
||||
Controlled->ABuSetModelShake( temp );
|
||||
// ABu: koniec rzucania
|
||||
*/
|
||||
if( (Train != nullptr)
|
||||
&& (Camera.Type == tp_Follow )) {
|
||||
// jeśli jazda w kabinie, przeliczyć trzeba parametry kamery
|
||||
vector3 tempangle = Controlled->VectorFront() * ( Controlled->MoverParameters->ActiveCab == -1 ? -1 : 1 );
|
||||
double modelrotate = atan2( -tempangle.x, tempangle.z );
|
||||
|
||||
if( Train->Dynamic()->MoverParameters->ActiveCab == 0 )
|
||||
Camera.LookAt = Train->pMechPosition + Train->GetDirection(); // gdy w korytarzu
|
||||
else // patrzenie w kierunku osi pojazdu, z uwzględnieniem kabiny
|
||||
Camera.LookAt = Train->pMechPosition +
|
||||
Train->GetDirection() *
|
||||
Train->Dynamic()->MoverParameters->ActiveCab; //-1 albo 1
|
||||
Camera.vUp = Train->GetUp();
|
||||
Global::SetCameraRotation( Camera.Yaw -
|
||||
modelrotate ); // tu już trzeba uwzględnić lusterka
|
||||
if( (Global::ctrlState)
|
||||
&& ( (Console::Pressed( Global::Keys[ k_MechLeft ])
|
||||
|| (Console::Pressed( Global::Keys[ k_MechRight ]))))) {
|
||||
// jeśli lusterko lewe albo prawe (bez rzucania na razie)
|
||||
bool lr = Console::Pressed( Global::Keys[ k_MechLeft ] );
|
||||
// Camera.Yaw powinno być wyzerowane, aby po powrocie patrzeć do przodu
|
||||
Camera.Pos = Controlled->GetPosition() + Train->MirrorPosition( lr ); // pozycja lusterka
|
||||
Camera.Yaw = 0; // odchylenie na bok od Camera.LookAt
|
||||
if( Train->Dynamic()->MoverParameters->ActiveCab == 0 )
|
||||
Camera.LookAt = Camera.Pos - Train->GetDirection(); // gdy w korytarzu
|
||||
else if( Global::shiftState ) {
|
||||
// patrzenie w bok przez szybę
|
||||
Camera.LookAt = Camera.Pos - ( lr ? -1 : 1 ) * Train->Dynamic()->VectorLeft() * Train->Dynamic()->MoverParameters->ActiveCab;
|
||||
Global::SetCameraRotation( -modelrotate );
|
||||
}
|
||||
else { // patrzenie w kierunku osi pojazdu, z uwzględnieniem kabiny - jakby z lusterka,
|
||||
// ale bez odbicia
|
||||
Camera.LookAt = Camera.Pos - Train->GetDirection() * Train->Dynamic()->MoverParameters->ActiveCab; //-1 albo 1
|
||||
Global::SetCameraRotation( M_PI - modelrotate ); // tu już trzeba uwzględnić lusterka
|
||||
}
|
||||
Camera.Roll = std::atan( Train->pMechShake.x * Train->fMechRoll ); // hustanie kamery na boki
|
||||
Camera.Pitch = 0.5 * std::atan( Train->vMechVelocity.z * Train->fMechPitch ); // hustanie kamery przod tyl
|
||||
Camera.vUp = Controlled->VectorUp();
|
||||
}
|
||||
else {
|
||||
// patrzenie standardowe
|
||||
Camera.Pos = Train->GetWorldMechPosition(); // Train.GetPosition1();
|
||||
if( !Global::iPause ) { // podczas pauzy nie przeliczać kątów przypadkowymi wartościami
|
||||
Camera.Roll = atan( Train->pMechShake.x * Train->fMechRoll ); // hustanie kamery na boki
|
||||
Camera.Pitch -= 0.5 * atan( Train->vMechVelocity.z * Train->fMechPitch ); // hustanie kamery przod tyl //Ra: tu
|
||||
// jest uciekanie kamery w górę!!!
|
||||
}
|
||||
// ABu011104: rzucanie pudlem
|
||||
/*
|
||||
vector3 temp;
|
||||
if( abs( Train->pMechShake.y ) < 0.25 )
|
||||
temp = vector3( 0, 0, 6 * Train->pMechShake.y );
|
||||
else if( ( Train->pMechShake.y ) > 0 )
|
||||
temp = vector3( 0, 0, 6 * 0.25 );
|
||||
else
|
||||
temp = vector3( 0, 0, -6 * 0.25 );
|
||||
if( Controlled )
|
||||
Controlled->ABuSetModelShake( temp );
|
||||
// ABu: koniec rzucania
|
||||
*/
|
||||
|
||||
if( Train->Dynamic()->MoverParameters->ActiveCab == 0 )
|
||||
Camera.LookAt = Train->GetWorldMechPosition() + Train->GetDirection() * 5.0; // gdy w korytarzu
|
||||
else // patrzenie w kierunku osi pojazdu, z uwzględnieniem kabiny
|
||||
Camera.LookAt = Train->GetWorldMechPosition() + Train->GetDirection() * 5.0 * Train->Dynamic()->MoverParameters->ActiveCab; //-1 albo 1
|
||||
Camera.vUp = Train->GetUp();
|
||||
Global::SetCameraRotation( Camera.Yaw - modelrotate ); // tu już trzeba uwzględnić lusterka
|
||||
}
|
||||
}
|
||||
else { // kamera nieruchoma
|
||||
|
||||
Reference in New Issue
Block a user