2018-05-15 17:58:09 +00:00
|
|
|
#ifndef OPENMW_WORLDSTATEAPI_HPP
|
|
|
|
#define OPENMW_WORLDSTATEAPI_HPP
|
|
|
|
|
|
|
|
#include "../Types.hpp"
|
|
|
|
|
|
|
|
#define WORLDSTATEAPI \
|
2018-06-07 09:49:12 +00:00
|
|
|
{"ReadLastWorldstate", WorldstateFunctions::ReadLastWorldstate},\
|
|
|
|
\
|
2018-06-26 23:00:16 +00:00
|
|
|
{"CopyLastWorldstateToStore", WorldstateFunctions::CopyLastWorldstateToStore},\
|
|
|
|
\
|
2018-06-07 09:49:12 +00:00
|
|
|
{"ClearMapChanges", WorldstateFunctions::ClearMapChanges},\
|
|
|
|
\
|
|
|
|
{"GetMapChangesSize", WorldstateFunctions::GetMapChangesSize},\
|
|
|
|
\
|
|
|
|
{"GetMapTileCellX", WorldstateFunctions::GetMapTileCellX},\
|
|
|
|
{"GetMapTileCellY", WorldstateFunctions::GetMapTileCellY},\
|
|
|
|
\
|
2018-05-27 13:05:40 +00:00
|
|
|
{"SetHour", WorldstateFunctions::SetHour},\
|
|
|
|
{"SetDay", WorldstateFunctions::SetDay},\
|
|
|
|
{"SetMonth", WorldstateFunctions::SetMonth},\
|
|
|
|
{"SetYear", WorldstateFunctions::SetYear},\
|
|
|
|
{"SetDaysPassed", WorldstateFunctions::SetDaysPassed},\
|
|
|
|
{"SetTimeScale", WorldstateFunctions::SetTimeScale},\
|
2018-05-25 00:33:12 +00:00
|
|
|
\
|
2018-05-27 13:05:40 +00:00
|
|
|
{"SetPlayerCollisionState", WorldstateFunctions::SetPlayerCollisionState},\
|
|
|
|
{"SetActorCollisionState", WorldstateFunctions::SetActorCollisionState},\
|
|
|
|
{"SetPlacedObjectCollisionState", WorldstateFunctions::SetPlacedObjectCollisionState},\
|
|
|
|
{"UseActorCollisionForPlacedObjects", WorldstateFunctions::UseActorCollisionForPlacedObjects},\
|
2018-05-24 06:38:06 +00:00
|
|
|
\
|
2018-06-28 01:53:00 +00:00
|
|
|
{"AddEnforcedCollisionRefId", WorldstateFunctions::AddEnforcedCollisionRefId},\
|
|
|
|
{"ClearEnforcedCollisionRefIds", WorldstateFunctions::ClearEnforcedCollisionRefIds},\
|
|
|
|
\
|
2018-06-28 00:48:16 +00:00
|
|
|
{"SaveMapTileImageFile", WorldstateFunctions::SaveMapTileImageFile},\
|
|
|
|
{"LoadMapTileImageFile", WorldstateFunctions::LoadMapTileImageFile},\
|
|
|
|
\
|
2018-06-07 09:49:12 +00:00
|
|
|
{"SendWorldMap", WorldstateFunctions::SendWorldMap},\
|
2018-05-27 13:05:40 +00:00
|
|
|
{"SendWorldTime", WorldstateFunctions::SendWorldTime},\
|
|
|
|
{"SendWorldCollisionOverride", WorldstateFunctions::SendWorldCollisionOverride}
|
2018-05-15 17:58:09 +00:00
|
|
|
|
|
|
|
class WorldstateFunctions
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
|
|
|
|
/**
|
2018-06-07 09:49:12 +00:00
|
|
|
* \brief Use the last worldstate received by the server as the one being read.
|
|
|
|
*
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void ReadLastWorldstate() noexcept;
|
|
|
|
|
2018-06-26 23:00:16 +00:00
|
|
|
/**
|
|
|
|
* \brief Take the contents of the read-only worldstate last received by the
|
|
|
|
* server from a player and move its contents to the stored worldstate
|
|
|
|
* that can be sent by the server.
|
|
|
|
*
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void CopyLastWorldstateToStore() noexcept;
|
|
|
|
|
2018-06-07 09:49:12 +00:00
|
|
|
/**
|
|
|
|
* \brief Clear the map changes for the write-only worldstate.
|
|
|
|
*
|
|
|
|
* This is used to initialize the sending of new WorldMap packets.
|
|
|
|
*
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void ClearMapChanges() noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the number of indexes in the read worldstate's map changes.
|
|
|
|
*
|
|
|
|
* \return The number of indexes.
|
|
|
|
*/
|
|
|
|
static unsigned int GetMapChangesSize() noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the X coordinate of the cell corresponding to the map tile at a certain index in
|
|
|
|
* the read worldstate's map changes.
|
|
|
|
*
|
|
|
|
* \param i The index of the map tile.
|
|
|
|
* \return The X coordinate of the cell.
|
|
|
|
*/
|
|
|
|
static int GetMapTileCellX(unsigned int index) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get the Y coordinate of the cell corresponding to the map tile at a certain index in
|
|
|
|
* the read worldstate's map changes.
|
|
|
|
*
|
|
|
|
* \param i The index of the map tile.
|
|
|
|
* \return The Y coordinate of the cell.
|
|
|
|
*/
|
|
|
|
static int GetMapTileCellY(unsigned int index) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set the world's hour in the write-only worldstate stored on the server.
|
2018-05-15 17:58:09 +00:00
|
|
|
*
|
|
|
|
* \param hour The hour.
|
|
|
|
* \return void
|
|
|
|
*/
|
2018-05-24 06:38:06 +00:00
|
|
|
static void SetHour(double hour) noexcept;
|
2018-05-15 17:58:09 +00:00
|
|
|
|
|
|
|
/**
|
2018-06-07 09:49:12 +00:00
|
|
|
* \brief Set the world's day in the write-only worldstate stored on the server.
|
2018-05-23 05:31:25 +00:00
|
|
|
*
|
|
|
|
* \param day The day.
|
|
|
|
* \return void
|
|
|
|
*/
|
2018-05-24 06:38:06 +00:00
|
|
|
static void SetDay(int day) noexcept;
|
2018-05-23 05:31:25 +00:00
|
|
|
|
|
|
|
/**
|
2018-06-07 09:49:12 +00:00
|
|
|
* \brief Set the world's month in the write-only worldstate stored on the server.
|
2018-05-15 17:58:09 +00:00
|
|
|
*
|
|
|
|
* \param month The month.
|
|
|
|
* \return void
|
|
|
|
*/
|
2018-05-24 06:38:06 +00:00
|
|
|
static void SetMonth(int month) noexcept;
|
2018-05-15 17:58:09 +00:00
|
|
|
|
2018-05-25 00:33:12 +00:00
|
|
|
/**
|
2018-06-07 09:49:12 +00:00
|
|
|
* \brief Set the world's year in the write-only worldstate stored on the server.
|
2018-05-25 00:33:12 +00:00
|
|
|
*
|
|
|
|
* \param year The year.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetYear(int year) noexcept;
|
|
|
|
|
2018-05-24 11:02:04 +00:00
|
|
|
/**
|
2018-06-07 09:49:12 +00:00
|
|
|
* \brief Set the world's days passed in the write-only worldstate stored on the server.
|
2018-05-24 11:02:04 +00:00
|
|
|
*
|
|
|
|
* \param daysPassed The days passed.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetDaysPassed(int daysPassed) noexcept;
|
|
|
|
|
2018-05-15 17:58:09 +00:00
|
|
|
/**
|
2018-06-07 09:49:12 +00:00
|
|
|
* \brief Set the world's time scale in the write-only worldstate stored on the server.
|
2018-05-15 17:58:09 +00:00
|
|
|
*
|
|
|
|
* \param pid The player ID.
|
2018-05-23 05:31:25 +00:00
|
|
|
* \param timeScale The time scale.
|
2018-05-15 17:58:09 +00:00
|
|
|
* \return void
|
|
|
|
*/
|
2018-05-24 06:38:06 +00:00
|
|
|
static void SetTimeScale(double timeScale) noexcept;
|
|
|
|
|
2018-05-27 13:05:40 +00:00
|
|
|
/**
|
2018-06-07 09:49:12 +00:00
|
|
|
* \brief Set the collision state for other players in the write-only worldstate stored
|
|
|
|
* on the server.
|
2018-05-27 13:05:40 +00:00
|
|
|
*
|
|
|
|
* \param state The collision state.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetPlayerCollisionState(bool state) noexcept;
|
|
|
|
|
|
|
|
/**
|
2018-06-07 09:49:12 +00:00
|
|
|
* \brief Set the collision state for actors in the write-only worldstate stored on the
|
|
|
|
* server.
|
2018-05-27 13:05:40 +00:00
|
|
|
*
|
|
|
|
* \param state The collision state.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetActorCollisionState(bool state) noexcept;
|
|
|
|
|
|
|
|
/**
|
2018-06-07 09:49:12 +00:00
|
|
|
* \brief Set the collision state for placed objects in the write-only worldstate stored
|
|
|
|
* on the server.
|
2018-05-27 13:05:40 +00:00
|
|
|
*
|
|
|
|
* \param state The collision state.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SetPlacedObjectCollisionState(bool state) noexcept;
|
|
|
|
|
|
|
|
/**
|
2018-06-07 09:49:12 +00:00
|
|
|
* \brief Whether placed objects with collision turned on should use actor collision, i.e.
|
|
|
|
* whether they should be slippery and prevent players from standing on them.
|
2018-05-27 13:05:40 +00:00
|
|
|
*
|
|
|
|
* \param useActorCollision Whether to use actor collision.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void UseActorCollisionForPlacedObjects(bool useActorCollision) noexcept;
|
|
|
|
|
2018-06-28 01:53:00 +00:00
|
|
|
/**
|
|
|
|
* \brief Add a refId to the list of refIds for which collision should be enforced
|
|
|
|
* irrespective of other settings.
|
|
|
|
*
|
|
|
|
* \param refId The refId.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void AddEnforcedCollisionRefId(const char* refId) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Clear the list of refIdsd for which collision should be enforced irrespective
|
|
|
|
* of other settings.
|
|
|
|
*
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void ClearEnforcedCollisionRefIds() noexcept;
|
|
|
|
|
2018-06-28 00:48:16 +00:00
|
|
|
/**
|
|
|
|
* \brief Save the .png image data of the map tile at a certain index in the read worldstate's
|
|
|
|
* map changes.
|
|
|
|
*
|
|
|
|
* \param i The index of the map tile.
|
|
|
|
* \param filePath The file path of the resulting file.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void SaveMapTileImageFile(unsigned int index, const char *filePath) noexcept;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Load a .png file as the image data for a map tile and add it to the write-only worldstate
|
|
|
|
* stored on the server.
|
|
|
|
*
|
|
|
|
* \param cellX The X coordinate of the cell corresponding to the map tile.
|
|
|
|
* \param cellY The Y coordinate of the cell corresponding to the map tile.
|
|
|
|
* \param filePath The file path of the loaded file.
|
|
|
|
* \return void
|
|
|
|
*/
|
|
|
|
static void LoadMapTileImageFile(int cellX, int cellY, const char* filePath) noexcept;
|
|
|
|
|
2018-05-24 06:38:06 +00:00
|
|
|
/**
|
2018-06-07 09:49:12 +00:00
|
|
|
* \brief Send a WorldMap packet with the current set of map changes in the write-only
|
|
|
|
* worldstate.
|
2018-05-24 06:38:06 +00:00
|
|
|
*
|
2018-06-07 09:49:12 +00:00
|
|
|
* \param pid The player ID attached to the packet.
|
|
|
|
* \param broadcast Whether this packet should be sent only to the attached player
|
|
|
|
* or to all players on the server.
|
2018-05-24 06:38:06 +00:00
|
|
|
* \return void
|
|
|
|
*/
|
2018-07-07 15:29:31 +00:00
|
|
|
static void SendWorldMap(unsigned short pid, bool sendToOtherPlayers = false, bool sendToAttachedPlayer = true) noexcept;
|
2018-05-15 17:58:09 +00:00
|
|
|
|
2018-05-27 13:05:40 +00:00
|
|
|
/**
|
2018-06-07 09:49:12 +00:00
|
|
|
* \brief Send a WorldTime packet with the current time and time scale in the write-only
|
|
|
|
* worldstate.
|
2018-05-27 13:05:40 +00:00
|
|
|
*
|
2018-06-07 09:49:12 +00:00
|
|
|
* \param pid The player ID attached to the packet.
|
2018-07-07 15:29:31 +00:00
|
|
|
* \param sendToOtherPlayers Whether this packet should be sent to players other than the
|
|
|
|
* player attached to the packet (false by default).
|
|
|
|
* \param sendToAttachedPlayer Whether the packet should be sent to the player attached
|
|
|
|
* to the packet (true by default).
|
2018-06-07 09:49:12 +00:00
|
|
|
* \return void
|
|
|
|
*/
|
2018-07-07 15:29:31 +00:00
|
|
|
static void SendWorldTime(unsigned short pid, bool sendToOtherPlayers = false, bool sendToAttachedPlayer = true) noexcept;
|
2018-06-07 09:49:12 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Send a WorldCollisionOverride packet with the current collision overrides in
|
|
|
|
* the write-only worldstate.
|
|
|
|
*
|
|
|
|
* \param pid The player ID attached to the packet.
|
2018-07-07 15:29:31 +00:00
|
|
|
* \param sendToOtherPlayers Whether this packet should be sent to players other than the
|
|
|
|
* player attached to the packet (false by default).
|
|
|
|
* \param sendToAttachedPlayer Whether the packet should be sent to the player attached
|
|
|
|
* to the packet (true by default).
|
2018-05-27 13:05:40 +00:00
|
|
|
* \return void
|
|
|
|
*/
|
2018-07-07 15:29:31 +00:00
|
|
|
static void SendWorldCollisionOverride(unsigned short pid, bool sendToOtherPlayers = false, bool sendToAttachedPlayer = true) noexcept;
|
2018-05-27 13:05:40 +00:00
|
|
|
|
2018-05-15 17:58:09 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif //OPENMW_WORLDSTATEAPI_HPP
|