2021-12-05 17:54:36 +00:00
|
|
|
/**
|
|
|
|
* Thanks to Simon for his early research on the racing system.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "BitStream.h"
|
|
|
|
#include "Entity.h"
|
|
|
|
#include "Component.h"
|
2023-03-04 07:16:37 +00:00
|
|
|
#include "eReplicaComponentType.h"
|
2024-10-27 03:59:50 +00:00
|
|
|
#include <chrono>
|
2021-12-05 17:54:36 +00:00
|
|
|
|
2022-07-28 13:39:57 +00:00
|
|
|
/**
|
|
|
|
* Information for each player in the race
|
|
|
|
*/
|
2021-12-05 17:54:36 +00:00
|
|
|
struct RacingPlayerInfo {
|
|
|
|
|
2022-07-28 13:39:57 +00:00
|
|
|
/**
|
|
|
|
* The ID of the player
|
|
|
|
*/
|
|
|
|
LWOOBJID playerID;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The ID of the car the player is driving
|
|
|
|
*/
|
|
|
|
LWOOBJID vehicleID;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The index of this player in the list of players
|
|
|
|
*/
|
|
|
|
uint32_t playerIndex;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Whether the player has finished loading or not
|
|
|
|
*/
|
|
|
|
bool playerLoaded;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Scripted activity component score
|
|
|
|
*/
|
|
|
|
float data[10]{};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Point that the player will respawn at if they smash their car
|
|
|
|
*/
|
|
|
|
NiPoint3 respawnPosition;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Rotation that the player will respawn at if they smash their car
|
|
|
|
*/
|
|
|
|
NiQuaternion respawnRotation;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The index in the respawn point the player is now at
|
|
|
|
*/
|
|
|
|
uint32_t respawnIndex;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The number of laps the player has completed
|
|
|
|
*/
|
|
|
|
uint32_t lap;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Whether or not the player has finished the race
|
|
|
|
*/
|
|
|
|
uint32_t finished;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Unused
|
|
|
|
*/
|
|
|
|
uint16_t reachedPoints;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The fastest lap time of the player
|
|
|
|
*/
|
2024-10-27 03:59:50 +00:00
|
|
|
std::chrono::milliseconds bestLapTime;
|
2022-07-28 13:39:57 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The current lap time of the player
|
|
|
|
*/
|
2024-10-27 03:59:50 +00:00
|
|
|
std::chrono::high_resolution_clock::time_point lapTime;
|
2022-07-28 13:39:57 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The number of times this player smashed their car
|
|
|
|
*/
|
|
|
|
uint32_t smashedTimes = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Whether or not the player should be smashed if the game is reloaded
|
|
|
|
*/
|
|
|
|
bool noSmashOnReload = false;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Whether or not this player has collected their rewards from completing the race
|
|
|
|
*/
|
|
|
|
bool collectedRewards = false;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Unused
|
|
|
|
*/
|
2024-10-27 03:59:50 +00:00
|
|
|
std::chrono::milliseconds raceTime;
|
2021-12-05 17:54:36 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Component that's attached to a manager entity in each race zone that loads player vehicles, keep scores, etc.
|
|
|
|
*/
|
2024-01-24 05:13:23 +00:00
|
|
|
class RacingControlComponent final : public Component {
|
2021-12-05 17:54:36 +00:00
|
|
|
public:
|
2024-01-24 05:13:23 +00:00
|
|
|
static constexpr eReplicaComponentType ComponentType = eReplicaComponentType::RACING_CONTROL;
|
2022-07-28 13:39:57 +00:00
|
|
|
|
2021-12-05 17:54:36 +00:00
|
|
|
RacingControlComponent(Entity* parentEntity);
|
|
|
|
~RacingControlComponent();
|
|
|
|
|
2024-02-27 07:25:44 +00:00
|
|
|
void Serialize(RakNet::BitStream& outBitStream, bool bIsInitialUpdate) override;
|
2023-08-10 21:33:15 +00:00
|
|
|
void Update(float deltaTime) override;
|
2022-07-28 13:39:57 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Invoked when a player loads into the zone.
|
|
|
|
*/
|
|
|
|
void OnPlayerLoaded(Entity* player);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Initalize the player's vehicle.
|
|
|
|
*
|
|
|
|
* @param player The player who's vehicle to initialize.
|
|
|
|
* @param initialLoad Is this the first time the player is loading in this race?
|
|
|
|
*/
|
2022-12-22 13:16:18 +00:00
|
|
|
void LoadPlayerVehicle(Entity* player, uint32_t positionNumber, bool initialLoad = false);
|
2022-07-28 13:39:57 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Invoked when the client says it has loaded in.
|
|
|
|
*/
|
|
|
|
void OnRacingClientReady(Entity* player);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Invoked when the client says it should be smashed.
|
|
|
|
*/
|
2025-01-01 18:54:21 +00:00
|
|
|
void OnRequestDie(Entity* player, const std::u16string& deathType = u"");
|
2022-07-28 13:39:57 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Invoked when the player has finished respawning.
|
|
|
|
*/
|
|
|
|
void OnRacingPlayerInfoResetFinished(Entity* player);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Invoked when the player responds to the GUI.
|
|
|
|
*/
|
2023-05-09 05:40:00 +00:00
|
|
|
void HandleMessageBoxResponse(Entity* player, int32_t button, const std::string& id);
|
2022-07-28 13:39:57 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the racing data from a player's LWOOBJID.
|
|
|
|
*/
|
|
|
|
RacingPlayerInfo* GetPlayerData(LWOOBJID playerID);
|
|
|
|
|
2024-12-20 07:59:22 +00:00
|
|
|
void MsgConfigureRacingControl(const GameMessages::ConfigureRacingControl& msg);
|
|
|
|
|
2021-12-05 17:54:36 +00:00
|
|
|
private:
|
|
|
|
|
2022-07-28 13:39:57 +00:00
|
|
|
/**
|
|
|
|
* The players that are currently racing
|
|
|
|
*/
|
|
|
|
std::vector<RacingPlayerInfo> m_RacingPlayers;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The paths that are followed for the camera scenes
|
2024-12-20 07:59:22 +00:00
|
|
|
* Configurable in the ConfigureRacingControl msg with the key `Race_PathName`.
|
2022-07-28 13:39:57 +00:00
|
|
|
*/
|
|
|
|
std::u16string m_PathName;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The ID of the activity for participating in this race
|
2024-12-20 07:59:22 +00:00
|
|
|
* Configurable in the ConfigureRacingControl msg with the key `activityID`.
|
2022-07-28 13:39:57 +00:00
|
|
|
*/
|
|
|
|
uint32_t m_ActivityID;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The world the players return to when they finish the race
|
|
|
|
*/
|
|
|
|
uint32_t m_MainWorld;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The number of laps that are remaining for the winning player
|
|
|
|
*/
|
|
|
|
uint16_t m_RemainingLaps;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The ID of the player that's currently winning the race
|
|
|
|
*/
|
|
|
|
LWOOBJID m_LeadingPlayer;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The overall best lap from all the players
|
|
|
|
*/
|
|
|
|
float m_RaceBestLap;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The overall best time from all the players
|
|
|
|
*/
|
|
|
|
float m_RaceBestTime;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Whether or not the race has started
|
|
|
|
*/
|
|
|
|
bool m_Started;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The time left until the race will start
|
|
|
|
*/
|
|
|
|
float m_StartTimer;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The time left for loading the players
|
|
|
|
*/
|
|
|
|
float m_LoadTimer;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Whether or not all players have loaded
|
|
|
|
*/
|
|
|
|
bool m_Loaded;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The number of loaded players
|
|
|
|
*/
|
|
|
|
uint32_t m_LoadedPlayers;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* All the players that are in the lobby, loaded or not
|
|
|
|
*/
|
|
|
|
std::vector<LWOOBJID> m_LobbyPlayers;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The number of players that have finished the race
|
|
|
|
*/
|
|
|
|
uint32_t m_Finished;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The time the race was started
|
|
|
|
*/
|
2024-10-27 03:59:50 +00:00
|
|
|
std::chrono::high_resolution_clock::time_point m_StartTime;
|
2022-07-28 13:39:57 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Timer for tracking how long a player was alone in this race
|
|
|
|
*/
|
|
|
|
float m_EmptyTimer;
|
|
|
|
|
|
|
|
bool m_SoloRacing;
|
2023-05-09 05:40:00 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Value for message box response to know if we are exiting the race via the activity dialogue
|
|
|
|
*/
|
|
|
|
const int32_t m_ActivityExitConfirm = 1;
|
2024-12-20 07:59:22 +00:00
|
|
|
|
2023-11-24 09:46:26 +00:00
|
|
|
bool m_AllPlayersReady = false;
|
2024-12-20 07:59:22 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief The number of laps in this race. Configurable in the ConfigureRacingControl msg
|
|
|
|
* with the key `Number_of_Laps`.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
int32_t m_NumberOfLaps{ 3 };
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief The minimum number of players required to progress group achievements.
|
|
|
|
* Configurable with the ConfigureRacingControl msg with the key `Minimum_Players_for_Group_Achievements`.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
int32_t m_MinimumPlayersForGroupAchievements{ 2 };
|
2021-12-05 17:54:36 +00:00
|
|
|
};
|