2017-05-24 20:22:43 +00:00
|
|
|
#ifndef OPENMW_DIALOGUEAPI_HPP
|
|
|
|
#define OPENMW_DIALOGUEAPI_HPP
|
|
|
|
|
|
|
|
#define DIALOGUEAPI \
|
2017-07-07 06:25:48 +00:00
|
|
|
{"InitializeTopicChanges", DialogueFunctions::InitializeTopicChanges},\
|
|
|
|
\
|
2017-05-24 20:22:43 +00:00
|
|
|
{"GetTopicChangesSize", DialogueFunctions::GetTopicChangesSize},\
|
|
|
|
\
|
|
|
|
{"AddTopic", DialogueFunctions::AddTopic},\
|
|
|
|
\
|
|
|
|
{"GetTopicId", DialogueFunctions::GetTopicId},\
|
|
|
|
\
|
2017-10-27 06:10:29 +00:00
|
|
|
{"SendTopicChanges", DialogueFunctions::SendTopicChanges},\
|
|
|
|
\
|
2017-10-31 13:19:14 +00:00
|
|
|
{"PlayAnimation", DialogueFunctions::PlayAnimation},\
|
|
|
|
{"PlaySpeech", DialogueFunctions::PlaySpeech}
|
2017-05-24 20:22:43 +00:00
|
|
|
|
|
|
|
class DialogueFunctions
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
|
2017-07-19 17:40:51 +00:00
|
|
|
/**
|
|
|
|
* \brief Clear the last recorded topic changes for a player.
|
|
|
|
*
|
|
|
|
* This is used to initialize the sending of new PlayerTopic packets.
|
|
|
|
*
|
|
|
|
* \param pid The player ID whose topic changes should be used.
|
|
|
|
* \return void
|
|
|
|
*/
|
2017-07-07 06:25:48 +00:00
|
|
|
static void InitializeTopicChanges(unsigned short pid) noexcept;
|
|
|
|
|
2017-07-19 17:40:51 +00:00
|
|
|
/**
|
|
|
|
* \brief Get the number of indexes in a player's latest topic changes.
|
|
|
|
*
|
|
|
|
* \param pid The player ID whose topic changes should be used.
|
|
|
|
* \return The number of indexes.
|
|
|
|
*/
|
2017-05-24 20:22:43 +00:00
|
|
|
static unsigned int GetTopicChangesSize(unsigned short pid) noexcept;
|
|
|
|
|
2017-07-19 17:40:51 +00:00
|
|
|
/**
|
|
|
|
* \brief Add a new topic to the topic changes for a player.
|
|
|
|
*
|
|
|
|
* \param pid The player ID whose topic changes should be used.
|
|
|
|
* \param topicId The topicId of the topic.
|
|
|
|
* \return void
|
|
|
|
*/
|
2017-05-24 20:22:43 +00:00
|
|
|
static void AddTopic(unsigned short pid, const char* topicId) noexcept;
|
|
|
|
|
2017-07-19 17:40:51 +00:00
|
|
|
/**
|
|
|
|
* \brief Get the topicId at a certain index in a player's latest topic changes.
|
|
|
|
*
|
|
|
|
* \param pid The player ID whose topic changes should be used.
|
2018-07-24 17:14:51 +00:00
|
|
|
* \param index The index of the topic.
|
2017-07-19 17:40:51 +00:00
|
|
|
* \return The topicId.
|
|
|
|
*/
|
2018-07-24 17:14:51 +00:00
|
|
|
static const char *GetTopicId(unsigned short pid, unsigned int index) noexcept;
|
2017-05-24 20:22:43 +00:00
|
|
|
|
2017-07-19 17:40:51 +00:00
|
|
|
/**
|
|
|
|
* \brief Send a PlayerTopic packet with a player's recorded topic changes.
|
|
|
|
*
|
|
|
|
* \param pid The player ID whose topic changes should be used.
|
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).
|
2018-07-07 17:16:36 +00:00
|
|
|
* \param skipAttachedPlayer Whether the packet should skip being sent to the player attached
|
|
|
|
* to the packet (false by default).
|
2017-07-19 17:40:51 +00:00
|
|
|
* \return void
|
|
|
|
*/
|
2018-07-07 17:08:59 +00:00
|
|
|
static void SendTopicChanges(unsigned short pid, bool sendToOtherPlayers, bool skipAttachedPlayer) noexcept;
|
2017-10-27 06:10:29 +00:00
|
|
|
|
2018-07-07 23:03:33 +00:00
|
|
|
/**
|
|
|
|
* \brief Play a certain animation on a player's character by sending a PlayerAnimation
|
|
|
|
* packet.
|
|
|
|
*
|
|
|
|
* \param pid The player ID of the character playing the animation.
|
|
|
|
* \param groupname The groupname of the animation.
|
|
|
|
* \param mode The mode of the animation.
|
|
|
|
* \param count The number of times the animation should be played.
|
|
|
|
* \param bool Whether the animation should persist or not.
|
|
|
|
* \return void
|
|
|
|
*/
|
2018-07-07 22:05:54 +00:00
|
|
|
static void PlayAnimation(unsigned short pid, const char* groupname, int mode, int count, bool persist) noexcept;
|
2018-07-07 23:03:33 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Play a certain sound for a player as spoken by their character by sending
|
|
|
|
* a PlayerSound packet.
|
|
|
|
*
|
|
|
|
* \param pid The player ID of the character playing the sound.
|
|
|
|
* \param sound The path of the sound file.
|
|
|
|
* \return void
|
|
|
|
*/
|
2017-10-31 13:19:14 +00:00
|
|
|
static void PlaySpeech(unsigned short pid, const char* sound) noexcept;
|
2017-10-27 06:10:29 +00:00
|
|
|
|
2017-05-24 20:22:43 +00:00
|
|
|
private:
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif //OPENMW_DIALOGUEAPI_HPP
|