mirror of
https://github.com/misternebula/quantum-space-buddies.git
synced 2025-01-01 03:32:38 +00:00
110 lines
3.8 KiB
C#
110 lines
3.8 KiB
C#
using System;
|
|
using OWML.Common;
|
|
using UnityEngine.Events;
|
|
|
|
public interface IQSBAPI
|
|
{
|
|
/// <summary>
|
|
/// If called, all players connected to YOUR hosted game must have this mod installed.
|
|
/// </summary>
|
|
void RegisterRequiredForAllPlayers(IModBehaviour mod);
|
|
|
|
/// <summary>
|
|
/// Returns if the current player is the host.
|
|
/// </summary>
|
|
bool GetIsHost();
|
|
|
|
/// <summary>
|
|
/// Returns if the current player is in multiplayer.
|
|
/// </summary>
|
|
bool GetIsInMultiplayer();
|
|
|
|
/// <summary>
|
|
/// Returns the player ID of the current player.
|
|
/// </summary>
|
|
uint GetLocalPlayerID();
|
|
|
|
/// <summary>
|
|
/// Returns the name of a given player.
|
|
/// </summary>
|
|
/// <param name="playerID">The ID of the player you want the name of.</param>
|
|
string GetPlayerName(uint playerID);
|
|
|
|
/// <summary>
|
|
/// Returns the list of IDs of all connected players.
|
|
///
|
|
/// The first player in the list is the host.
|
|
/// </summary>
|
|
uint[] GetPlayerIDs();
|
|
|
|
/// <summary>
|
|
/// Invoked when any player (local or remote) joins the game.
|
|
/// </summary>
|
|
UnityEvent<uint> OnPlayerJoin();
|
|
|
|
/// <summary>
|
|
/// Invoked when any player (local or remote) leaves the game.
|
|
/// </summary>
|
|
UnityEvent<uint> OnPlayerLeave();
|
|
|
|
/// <summary>
|
|
/// Invoked when the local client joins a game,
|
|
/// either through connecting to an external game or hosting their own game.
|
|
/// </summary>
|
|
UnityEvent OnLocalJoin();
|
|
|
|
/// <summary>
|
|
/// Invoked when a client (but not the local player) joins the game.
|
|
/// </summary>
|
|
UnityEvent<uint> OnPeerJoin();
|
|
|
|
/// <summary>
|
|
/// Invoked when the local client leaves a game,
|
|
/// either through disconnecting from an external game or shutting down the hosted server.
|
|
/// </summary>
|
|
UnityEvent OnLocalLeave();
|
|
|
|
/// <summary>
|
|
/// Invoked when a client (but not the local player) leaves the game.
|
|
/// </summary>
|
|
UnityEvent<uint> OnPeerLeave();
|
|
|
|
/// <summary>
|
|
/// Sets some arbitrary data for a given player.
|
|
/// </summary>
|
|
/// <typeparam name="T">The type of the data.</typeparam>
|
|
/// <param name="playerId">The ID of the player.</param>
|
|
/// <param name="key">The unique key to access this data by.</param>
|
|
/// <param name="data">The data to set.</param>
|
|
void SetCustomData<T>(uint playerId, string key, T data);
|
|
|
|
/// <summary>
|
|
/// Returns some arbitrary data from a given player.
|
|
/// </summary>
|
|
/// <typeparam name="T">The type of the data.</typeparam>
|
|
/// <param name="playerId">The ID of the player.</param>
|
|
/// <param name="key">The unique key of the data you want to access.</param>
|
|
/// <returns>The data requested. If key is not valid, returns default.</returns>
|
|
T GetCustomData<T>(uint playerId, string key);
|
|
|
|
/// <summary>
|
|
/// Sends a message containing arbitrary data to every player.
|
|
///
|
|
/// Keep your messages under around 1100 bytes.
|
|
/// </summary>
|
|
/// <typeparam name="T">The type of the data being sent. This type must be serializable.</typeparam>
|
|
/// <param name="messageType">The unique key of the message.</param>
|
|
/// <param name="data">The data to send.</param>
|
|
/// <param name="to">The player to send this message to. (0 is the host, uint.MaxValue means every player)</param>
|
|
/// <param name="receiveLocally">If true, the action given to <see cref="RegisterHandler{T}"/> will also be called on the same client that is sending the message.</param>
|
|
void SendMessage<T>(string messageType, T data, uint to = uint.MaxValue, bool receiveLocally = false);
|
|
|
|
/// <summary>
|
|
/// Registers an action to be called when a message is received.
|
|
/// </summary>
|
|
/// <typeparam name="T">The type of the data in the message.</typeparam>
|
|
/// <param name="messageType">The unique key of the message.</param>
|
|
/// <param name="handler">The action to be ran when the message is received. The uint is the player ID that sent the messsage.</param>
|
|
void RegisterHandler<T>(string messageType, Action<uint, T> handler);
|
|
}
|