Added command to center camera on player when walking, double click X button to do it

This commit is contained in:
Soniccd123 2024-12-27 18:00:52 -03:00 committed by Stefanos Kornilios Mitsis Poiitidis
parent 267f39b9fd
commit d0c97eedb5
2 changed files with 69 additions and 34 deletions

View File

@ -1562,38 +1562,12 @@ void CPad::Update(int16 pad)
bHornHistory[iCurrHornHistory] = GetHorn(); bHornHistory[iCurrHornHistory] = GetHorn();
#ifdef RW_DC #ifdef RW_DC
auto old_contMaple = contMaple; //auto old_contMaple = contMaple;
auto n_dev = maple_enum_count(); auto n_dev = maple_enum_count();
contMaple = maple_enum_type(0, MAPLE_FUNC_CONTROLLER); contMaple = maple_enum_type(0, MAPLE_FUNC_CONTROLLER);
state = (cont_state_t *)maple_dev_status(contMaple); state = (cont_state_t *)maple_dev_status(contMaple);
#endif #endif
// if (n_dev == 0)
// {
// CPad::GetPad(0)->IsDualAnalog = false;
// NewState.DPadUp = 0;
// NewState.DPadDown = 0;
// NewState.DPadLeft = 0;
// NewState.DPadRight = 0;
// NewState.A = 0;
// NewState.B = 0;
// NewState.C = 0;
// NewState.D = 0;
// NewState.X = 0;
// NewState.Y = 0;
// NewState.Z = 0;
// NewState.Start = 0;
// NewState.RightTrigger = 0;
// NewState.LeftTrigger = 0;
// NewState.LeftStickX = 0;
// NewState.LeftStickY = 0;
// NewState.RightStickX = 0;
// NewState.RightStickY = 0;
// NewState.RightShock = 0;
// }
if ( !bDisplayNoControllerMessage ) if ( !bDisplayNoControllerMessage )
CGame::bDemoMode = false; CGame::bDemoMode = false;
@ -1692,6 +1666,54 @@ CPad *CPad::GetPad(int32 pad)
//While i think its possible, creating a system to configure custom mappings inside the game menus like in the PC game is out of my scope in the moment, I don't know if this is really necessary //While i think its possible, creating a system to configure custom mappings inside the game menus like in the PC game is out of my scope in the moment, I don't know if this is really necessary
//Also, the interface controls are not defined here, they are defined in Frontend.cpp unfortunately, using CControllerState values like here; Because of that, the behavior of the Start button and the A button for selecting menu itens are not here //Also, the interface controls are not defined here, they are defined in Frontend.cpp unfortunately, using CControllerState values like here; Because of that, the behavior of the Start button and the A button for selecting menu itens are not here
#ifdef RW_DC
bool CPad::CameraSinglePress (void)
{
if (CPad::CameraDoublePress() == false && NewState.X == true)
return true;
return 0;
}
bool CPad::CameraDoublePress (void)
{
if ( ArePlayerControlsDisabled() ) //Wont work driving, camera code isnt there
return false;
if ((OldState.X == 1) && (NewState.X == 0) //Falling edge
&& (CPad::GetPad(0)->CameraIsDoublePressed == false)) //Was not in double click state
{
//CPad::GetPad(0)->CameraJustUp = true;
CPad::GetPad(0)->CameraLastPressed = psTimer(); //Set timer to run
}
if ((OldState.X == 1) && (NewState.X == 0) //Falling edge
&& (CPad::GetPad(0)->CameraIsDoublePressed == true)) //Was in double click state
{
CPad::GetPad(0)->CameraIsDoublePressed = false; //ends double click state
return 0;
}
if ((OldState.X == 0) && (NewState.X == 1) //Rising edge
&& ((psTimer() - CPad::GetPad(0)->CameraLastPressed) < 250)) //Checks timer on the Rising edge of X press
{
CPad::GetPad(0)->CameraIsDoublePressed = true; //Define that there was a double click
return true;
}
if ((OldState.X == 1) && (NewState.X == 1) //Button is keep pressed
&& (CameraIsDoublePressed == true)) //The last state was double click
{
CPad::GetPad(0)->CameraIsDoublePressed = true; //Keep double click state
return true;
}
return 0;
}
#endif
int16 CPad::GetSteeringLeftRight(void) int16 CPad::GetSteeringLeftRight(void)
{ {
if ( ArePlayerControlsDisabled() ) if ( ArePlayerControlsDisabled() )
@ -1952,7 +1974,7 @@ int16 axis = 0;
} }
else else
{ {
if (NewState.X) if (CPad::CameraSinglePress())
return 0; return 0;
axis = NewState.LeftStickX; axis = NewState.LeftStickX;
} }
@ -2022,7 +2044,7 @@ int16 axis = 0;
} }
else else
{ {
if (NewState.X) if (CPad::CameraSinglePress())
return 0; return 0;
axis = NewState.LeftStickY; axis = NewState.LeftStickY;
} }
@ -3545,9 +3567,13 @@ bool CPad::GetAnaloguePadRightJustUp(void)
bool CPad::ForceCameraBehindPlayer(void) bool CPad::ForceCameraBehindPlayer(void)
{ {
if ( ArePlayerControlsDisabled() ) if ( ArePlayerControlsDisabled() ) //Wont work driving, camera code isnt there
return false; return false;
#ifdef RW_DC
if (CPad::CameraDoublePress())
return true;
#else
switch (CURMODE) switch (CURMODE)
{ {
case 0: case 0:
@ -3572,7 +3598,7 @@ bool CPad::ForceCameraBehindPlayer(void)
break; break;
} }
} }
#endif
return false; return false;
} }
@ -3713,7 +3739,7 @@ float axis = 0;
} }
else else
{ {
if (!NewState.X) if (!CPad::CameraSinglePress())
return 0; return 0;
axis = NewState.LeftStickX; axis = NewState.LeftStickX;
} }
@ -3760,7 +3786,7 @@ int16 CPad::LookAroundUpDown(void)
} }
else else
{ {
if (!NewState.X) if (!CPad::CameraSinglePress())
return 0; return 0;
axis = NewState.LeftStickY; axis = NewState.LeftStickY;
} }

View File

@ -163,6 +163,11 @@ public:
int32 AverageEntries; int32 AverageEntries;
bool IsKeyboardMouse; bool IsKeyboardMouse;
bool IsDualAnalog; bool IsDualAnalog;
bool CameraJustDown;
bool CameraJustUp;
uint32 CameraJustUpTime;
uint32 CameraLastPressed;
bool CameraIsDoublePressed;
#ifdef DETECT_PAD_INPUT_SWITCH #ifdef DETECT_PAD_INPUT_SWITCH
static bool IsAffectedByController; static bool IsAffectedByController;
@ -213,7 +218,11 @@ public:
void StopShaking(int16 pad); void StopShaking(int16 pad);
static CPad *GetPad(int32 pad); static CPad *GetPad(int32 pad);
#ifdef RW_DC
bool CameraSinglePress(void); //Checks if camera modifier was double clicked
bool CameraDoublePress(void);
#endif
int16 GetSteeringLeftRight(void); int16 GetSteeringLeftRight(void);
int16 GetSteeringUpDown(void); int16 GetSteeringUpDown(void);
int16 GetCarGunUpDown(void); int16 GetCarGunUpDown(void);