RAGECOOP-V/Client/COOPAPI.cs

295 lines
9.4 KiB
C#
Raw Normal View History

2021-11-19 22:08:15 +01:00
using System.Collections.Generic;
2021-09-28 16:51:16 +02:00
using System.ComponentModel;
2021-09-30 23:35:42 +02:00
using System.Linq;
2021-12-27 10:15:52 +01:00
using CoopClient.Entities.Player;
namespace CoopClient
{
/// <summary>
/// ?
/// </summary>
public static class COOPAPI
{
2021-09-27 19:10:51 +02:00
#region DELEGATES
/// <summary>
/// ?
/// </summary>
2021-12-14 22:51:09 +01:00
/// <param name="connected"></param>
/// <param name="from">The Lidgren-Network net handle</param>
/// <param name="reason"></param>
public delegate void ConnectEvent(bool connected, long from, string reason = null);
/// <summary>
/// ?
/// </summary>
2021-12-14 22:51:09 +01:00
/// <param name="from"></param>
/// <param name="message">The Lidgren-Network net handle</param>
/// <param name="args"></param>
public delegate void ChatMessage(string from, string message, CancelEventArgs args);
/// <summary>
/// ?
/// </summary>
2021-12-14 22:51:09 +01:00
/// <param name="from">The Lidgren-Network net handle</param>
/// <param name="mod"></param>
/// <param name="customID"></param>
/// <param name="bytes"></param>
2021-09-29 14:34:22 +02:00
public delegate void ModEvent(long from, string mod, byte customID, byte[] bytes);
2021-09-27 19:10:51 +02:00
#endregion
#region EVENTS
/// <summary>
/// ?
/// </summary>
public static event ConnectEvent OnConnection;
/// <summary>
/// ?
/// </summary>
public static event ChatMessage OnChatMessage;
/// <summary>
/// ?
/// </summary>
2021-09-29 14:34:22 +02:00
public static event ModEvent OnModPacketReceived;
internal static void Connected()
{
2021-12-14 22:51:09 +01:00
OnConnection?.Invoke(true, GetLocalNetHandle());
}
internal static void Disconnected(string reason)
{
2021-12-14 22:51:09 +01:00
OnConnection?.Invoke(false, GetLocalNetHandle(), reason);
}
2021-12-14 22:51:09 +01:00
internal static void Connected(long netHandle)
{
2021-12-14 22:51:09 +01:00
OnConnection?.Invoke(true, netHandle);
}
2021-12-14 22:51:09 +01:00
internal static void Disconnected(long netHandle)
{
2021-12-14 22:51:09 +01:00
OnConnection?.Invoke(false, netHandle);
}
2021-09-29 14:34:22 +02:00
internal static void ModPacketReceived(long from, string mod, byte customID, byte[] bytes)
{
2021-09-29 14:34:22 +02:00
OnModPacketReceived?.Invoke(from, mod, customID, bytes);
}
internal static bool ChatMessageReceived(string from, string message)
{
CancelEventArgs args = new CancelEventArgs(false);
OnChatMessage?.Invoke(from, message, args);
return args.Cancel;
}
2021-09-27 19:10:51 +02:00
#endregion
/// <summary>
/// Send a local chat message to this player
/// </summary>
/// <param name="from">Username of the player who sent this message</param>
/// <param name="message">The player's message</param>
public static void LocalChatMessage(string from, string message)
{
Main.MainChat.AddMessage(from, message);
}
/// <summary>
/// Connect to any server
/// </summary>
/// <param name="serverAddress">The server address to connect. Example: 127.0.0.1:4499</param>
2021-09-27 19:10:51 +02:00
public static void Connect(string serverAddress)
{
2021-09-27 19:10:51 +02:00
Main.MainNetworking.DisConnectFromServer(serverAddress);
}
/// <summary>
/// ?
/// </summary>
2021-09-29 14:34:22 +02:00
public static void Disconnect()
{
Main.MainNetworking.DisConnectFromServer(null);
}
/// <summary>
2021-12-16 14:52:48 +01:00
/// Check if the player is already on a server
/// </summary>
public static bool IsOnServer()
{
return Main.MainNetworking.IsOnServer();
}
/// <summary>
2021-12-16 14:52:48 +01:00
/// Get the local net handle from this Lidgren-Network client when connected to a server
/// </summary>
/// <returns>NetHandle</returns>
2021-12-14 22:51:09 +01:00
public static long GetLocalNetHandle()
2021-09-29 14:34:22 +02:00
{
return Main.LocalNetHandle;
2021-09-29 14:34:22 +02:00
}
/// <summary>
/// Get all connected player's as a Dictionary.
/// Key = Lidgren-Network net handle.
/// Value = Character handle or null.
/// </summary>
2021-09-30 23:35:42 +02:00
public static Dictionary<long, int?> GetAllPlayers()
{
Dictionary<long, int?> result = new Dictionary<long, int?>();
lock (Main.Players)
{
2021-12-27 10:15:52 +01:00
foreach (KeyValuePair<long, EntitiesPlayer> player in Main.Players.Where(x => x.Key != Main.LocalNetHandle))
2021-09-30 23:35:42 +02:00
{
result.Add(player.Key, player.Value.Character?.Handle);
}
}
return result;
}
/// <summary>
/// Get a player using their Lidgren Network net handle
/// </summary>
/// <param name="handle">Lidgren-Network net handle</param>
2021-12-27 10:15:52 +01:00
public static EntitiesPlayer GetPlayer(long handle)
{
lock (Main.Players)
{
return Main.Players.ContainsKey(handle) ? Main.Players[handle] : null;
}
}
/// <summary>
2021-12-16 14:52:48 +01:00
/// Check if a GTACOOP:R menu is visible
/// </summary>
2021-09-28 16:51:16 +02:00
public static bool IsMenuVisible()
{
2021-09-29 14:34:22 +02:00
#if NON_INTERACTIVE
return false;
#else
2021-09-28 16:51:16 +02:00
return Main.MainMenu.MenuPool.AreAnyVisible;
2021-09-29 14:34:22 +02:00
#endif
2021-09-28 16:51:16 +02:00
}
/// <summary>
2021-12-16 14:52:48 +01:00
/// Check if the GTACOOP:R chat is visible
/// </summary>
2021-09-28 16:51:16 +02:00
public static bool IsChatFocused()
{
return Main.MainChat.Focused;
}
/// <summary>
2021-12-16 14:52:48 +01:00
/// Check if the GTACOOP:R list of players is visible
/// </summary>
2021-09-28 16:51:16 +02:00
public static bool IsPlayerListVisible()
{
2021-11-19 22:08:15 +01:00
return Util.GetTickCount64() - PlayerList.Pressed < 5000;
2021-09-28 16:51:16 +02:00
}
/// <summary>
/// Get the version of GTACOOP:R
/// </summary>
2021-09-28 16:51:16 +02:00
public static string GetCurrentVersion()
{
return Main.CurrentVersion;
}
/// <summary>
/// Send any data (bytes) to the server
/// </summary>
2022-01-01 03:07:18 +01:00
/// <param name="modName">The name of this modification (script)</param>
/// <param name="customID">The ID to know what the data is</param>
/// <param name="bytes">Your class, structure or whatever in bytes</param>
2022-01-01 03:07:18 +01:00
public static void SendDataToServer(string modName, byte customID, byte[] bytes)
{
2022-01-01 03:07:18 +01:00
Main.MainNetworking.SendModData(-1, modName, customID, bytes);
}
/// <summary>
/// Send any data (bytes) to the all player
/// </summary>
2022-01-01 03:07:18 +01:00
/// <param name="modName">The name of this modification (script)</param>
/// <param name="customID">The ID to know what the data is</param>
/// <param name="bytes">Your class, structure or whatever in bytes</param>
2022-01-01 03:07:18 +01:00
public static void SendDataToAll(string modName, byte customID, byte[] bytes)
2021-09-29 14:34:22 +02:00
{
2022-01-01 03:07:18 +01:00
Main.MainNetworking.SendModData(0, modName, customID, bytes);
2021-09-30 23:35:42 +02:00
}
/// <summary>
/// Send any data (bytes) to a player
/// </summary>
2021-12-14 22:51:09 +01:00
/// <param name="netHandle">The Lidgren Network net handle that receives the data</param>
2022-01-01 03:07:18 +01:00
/// <param name="modName">The name of this modification (script)</param>
/// <param name="customID">The ID to know what the data is</param>
/// <param name="bytes">Your class, structure or whatever in bytes</param>
2022-01-01 03:07:18 +01:00
public static void SendDataToPlayer(long netHandle, string modName, byte customID, byte[] bytes)
2021-09-30 23:35:42 +02:00
{
2022-01-01 03:07:18 +01:00
Main.MainNetworking.SendModData(netHandle, modName, customID, bytes);
2021-09-29 14:34:22 +02:00
}
/// <summary>
/// Get that player's local username
/// </summary>
public static string GetUsername()
{
return Main.MainSettings.Username;
}
/// <summary>
/// Set a new username for this player
/// </summary>
/// <param name="username">The new username</param>
/// <returns>false if the player already joined a server or the username is null or empty otherwise true</returns>
public static bool SetUsername(string username)
{
if (IsOnServer() || string.IsNullOrEmpty(username))
{
return false;
}
Main.MainSettings.Username = username;
return true;
}
/// <summary>
/// Enable or disable sharing of NPCs with other players
/// </summary>
/// <param name="share">true to share NPCs</param>
public static void SetShareNPCs(bool share)
{
Main.ShareNPCsWithPlayers = share;
}
/// <summary>
/// Enable or disable the local traffic for this player
/// </summary>
/// <param name="enable">true to disable traffic</param>
public static void SetLocalTraffic(bool enable)
{
Main.DisableTraffic = !enable;
}
/// <summary>
/// Sets the alignment for the player list, if set to true it will align left,
/// otherwise it will align right
/// </summary>
/// <param name="leftAlign">true to move the player list to the left</param>
public static void SetPlayerListLeftAlign(bool leftAlign)
{
PlayerList.LeftAlign = leftAlign;
}
2021-09-27 19:10:51 +02:00
#if DEBUG
/// <summary>
/// ?
/// </summary>
/// <param name="value"></param>
public static void SetDebug(bool value)
{
Main.UseDebug = value;
}
#endif
}
}