2022-05-22 15:55:26 +08:00
|
|
|
|
#undef DEBUG
|
|
|
|
|
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;
|
2022-05-22 15:55:26 +08:00
|
|
|
|
using RageCoop.Core;
|
2021-09-27 20:28:27 +02:00
|
|
|
|
|
2022-05-22 15:55:26 +08:00
|
|
|
|
namespace RageCoop.Client
|
2021-09-26 20:52:23 -06:00
|
|
|
|
{
|
2021-11-28 23:35:37 +01:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// ?
|
|
|
|
|
/// </summary>
|
2021-11-27 22:44:00 +01:00
|
|
|
|
public static class COOPAPI
|
2021-09-26 20:52:23 -06:00
|
|
|
|
{
|
2022-05-31 02:16:12 -08:00
|
|
|
|
|
2021-09-27 19:10:51 +02:00
|
|
|
|
#region DELEGATES
|
2021-11-28 23:35:37 +01:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// ?
|
|
|
|
|
/// </summary>
|
2021-12-14 22:51:09 +01:00
|
|
|
|
/// <param name="connected"></param>
|
2022-05-31 02:16:12 -08:00
|
|
|
|
/// <param name="from">The player's id</param>
|
2021-12-14 22:51:09 +01:00
|
|
|
|
/// <param name="reason"></param>
|
2022-05-31 02:16:12 -08:00
|
|
|
|
public delegate void ConnectEvent(bool connected, int from, string reason = null);
|
2021-11-28 23:35:37 +01:00
|
|
|
|
/// <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>
|
2021-09-27 20:28:27 +02:00
|
|
|
|
public delegate void ChatMessage(string from, string message, CancelEventArgs args);
|
2021-11-28 23:35:37 +01:00
|
|
|
|
/// <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
|
2021-11-28 23:35:37 +01:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// ?
|
|
|
|
|
/// </summary>
|
2021-09-27 22:40:18 +02:00
|
|
|
|
public static event ConnectEvent OnConnection;
|
2021-11-28 23:35:37 +01:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// ?
|
|
|
|
|
/// </summary>
|
2021-09-27 20:28:27 +02:00
|
|
|
|
public static event ChatMessage OnChatMessage;
|
2021-09-26 20:52:23 -06:00
|
|
|
|
|
2022-05-22 15:55:26 +08:00
|
|
|
|
public static void Connected()
|
2021-09-26 20:52:23 -06:00
|
|
|
|
{
|
2022-05-22 15:55:26 +08:00
|
|
|
|
OnConnection?.Invoke(true, GetPlayerID());
|
2021-09-26 20:52:23 -06:00
|
|
|
|
}
|
|
|
|
|
|
2022-05-22 15:55:26 +08:00
|
|
|
|
public static void Disconnected(string reason)
|
2021-09-26 20:52:23 -06:00
|
|
|
|
{
|
2022-05-22 15:55:26 +08:00
|
|
|
|
OnConnection?.Invoke(false, GetPlayerID(), reason);
|
2021-11-19 17:05:57 -07:00
|
|
|
|
}
|
|
|
|
|
|
2022-05-31 09:14:30 +08:00
|
|
|
|
public static void Connected(int playerID)
|
2021-11-19 17:05:57 -07:00
|
|
|
|
{
|
2022-05-31 09:14:30 +08:00
|
|
|
|
OnConnection?.Invoke(true, playerID);
|
2021-11-19 17:05:57 -07:00
|
|
|
|
}
|
|
|
|
|
|
2022-05-31 02:16:12 -08:00
|
|
|
|
public static void Disconnected(int playerID)
|
2021-11-19 17:05:57 -07:00
|
|
|
|
{
|
2022-05-31 02:16:12 -08:00
|
|
|
|
OnConnection?.Invoke(false, playerID);
|
2021-09-26 20:52:23 -06:00
|
|
|
|
}
|
|
|
|
|
|
2022-05-22 15:55:26 +08:00
|
|
|
|
public static bool ChatMessageReceived(string from, string message)
|
2021-09-27 20:28:27 +02:00
|
|
|
|
{
|
|
|
|
|
CancelEventArgs args = new CancelEventArgs(false);
|
|
|
|
|
OnChatMessage?.Invoke(from, message, args);
|
|
|
|
|
return args.Cancel;
|
|
|
|
|
}
|
2021-09-27 19:10:51 +02:00
|
|
|
|
#endregion
|
2021-09-26 20:52:23 -06:00
|
|
|
|
|
2021-11-28 23:35:37 +01:00
|
|
|
|
/// <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>
|
2021-11-27 00:39:14 +01:00
|
|
|
|
public static void LocalChatMessage(string from, string message)
|
2021-09-27 20:28:27 +02:00
|
|
|
|
{
|
|
|
|
|
Main.MainChat.AddMessage(from, message);
|
|
|
|
|
}
|
|
|
|
|
|
2021-11-28 23:35:37 +01:00
|
|
|
|
/// <summary>
|
2022-03-25 15:45:22 +01:00
|
|
|
|
/// Connect to any server
|
2021-11-28 23:35:37 +01:00
|
|
|
|
/// </summary>
|
2022-03-25 15:45:22 +01:00
|
|
|
|
/// <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-26 20:52:23 -06:00
|
|
|
|
{
|
2022-05-31 23:12:32 -08:00
|
|
|
|
Networking.ToggleConnection(serverAddress);
|
2021-09-26 20:52:23 -06:00
|
|
|
|
}
|
|
|
|
|
|
2021-11-28 23:35:37 +01:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// ?
|
|
|
|
|
/// </summary>
|
2021-09-29 14:34:22 +02:00
|
|
|
|
public static void Disconnect()
|
|
|
|
|
{
|
2022-05-31 23:12:32 -08:00
|
|
|
|
Networking.ToggleConnection(null);
|
2021-09-29 14:34:22 +02:00
|
|
|
|
}
|
|
|
|
|
|
2021-11-28 23:35:37 +01:00
|
|
|
|
/// <summary>
|
2021-12-16 14:52:48 +01:00
|
|
|
|
/// Check if the player is already on a server
|
2021-11-28 23:35:37 +01:00
|
|
|
|
/// </summary>
|
2021-09-27 22:40:18 +02:00
|
|
|
|
public static bool IsOnServer()
|
|
|
|
|
{
|
2022-05-25 11:32:34 +08:00
|
|
|
|
return Networking.IsOnServer;
|
2021-09-27 22:40:18 +02:00
|
|
|
|
}
|
|
|
|
|
|
2021-11-28 23:35:37 +01:00
|
|
|
|
/// <summary>
|
2022-05-22 15:55:26 +08:00
|
|
|
|
/// Get the local player's ID
|
2021-11-28 23:35:37 +01:00
|
|
|
|
/// </summary>
|
2022-05-22 15:55:26 +08:00
|
|
|
|
/// <returns>PlayerID</returns>
|
2022-05-31 02:16:12 -08:00
|
|
|
|
public static int GetPlayerID()
|
2021-09-29 14:34:22 +02:00
|
|
|
|
{
|
2022-05-23 16:59:49 +08:00
|
|
|
|
return Main.LocalPlayerID;
|
2021-09-29 14:34:22 +02:00
|
|
|
|
}
|
|
|
|
|
|
2021-11-28 23:35:37 +01:00
|
|
|
|
/// <summary>
|
2022-04-06 02:18:24 +02:00
|
|
|
|
/// Check if a RAGECOOP menu is visible
|
2021-11-28 23:35:37 +01:00
|
|
|
|
/// </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
|
2022-05-31 09:14:30 +08:00
|
|
|
|
return Menus.CoopMenu.MenuPool.AreAnyVisible;
|
2021-09-29 14:34:22 +02:00
|
|
|
|
#endif
|
2021-09-28 16:51:16 +02:00
|
|
|
|
}
|
|
|
|
|
|
2021-11-28 23:35:37 +01:00
|
|
|
|
/// <summary>
|
2022-04-06 02:18:24 +02:00
|
|
|
|
/// Check if the RAGECOOP chat is visible
|
2021-11-28 23:35:37 +01:00
|
|
|
|
/// </summary>
|
2021-09-28 16:51:16 +02:00
|
|
|
|
public static bool IsChatFocused()
|
|
|
|
|
{
|
|
|
|
|
return Main.MainChat.Focused;
|
|
|
|
|
}
|
|
|
|
|
|
2021-11-28 23:35:37 +01:00
|
|
|
|
/// <summary>
|
2022-04-06 02:18:24 +02:00
|
|
|
|
/// Check if the RAGECOOP list of players is visible
|
2021-11-28 23:35:37 +01:00
|
|
|
|
/// </summary>
|
2021-09-28 16:51:16 +02:00
|
|
|
|
public static bool IsPlayerListVisible()
|
|
|
|
|
{
|
2022-05-23 16:59:49 +08:00
|
|
|
|
return Util.GetTickCount64() - PlayerList.Pressed < 5000;
|
2021-09-28 16:51:16 +02:00
|
|
|
|
}
|
|
|
|
|
|
2021-11-28 23:35:37 +01:00
|
|
|
|
/// <summary>
|
2022-04-06 02:18:24 +02:00
|
|
|
|
/// Get the version of RAGECOOP
|
2021-11-28 23:35:37 +01:00
|
|
|
|
/// </summary>
|
2021-09-28 16:51:16 +02:00
|
|
|
|
public static string GetCurrentVersion()
|
|
|
|
|
{
|
|
|
|
|
return Main.CurrentVersion;
|
|
|
|
|
}
|
|
|
|
|
|
2021-11-28 23:35:37 +01:00
|
|
|
|
/// <summary>
|
2021-12-14 22:39:15 +01:00
|
|
|
|
/// Get that player's local username
|
2021-11-28 23:35:37 +01:00
|
|
|
|
/// </summary>
|
2021-12-14 22:39:15 +01:00
|
|
|
|
public static string GetUsername()
|
2021-11-27 22:44:00 +01:00
|
|
|
|
{
|
2022-05-22 15:55:26 +08:00
|
|
|
|
return Main.Settings.Username;
|
2021-11-27 22:44:00 +01:00
|
|
|
|
}
|
|
|
|
|
|
2021-11-28 23:35:37 +01:00
|
|
|
|
/// <summary>
|
2021-12-14 22:39:15 +01:00
|
|
|
|
/// 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;
|
|
|
|
|
}
|
|
|
|
|
|
2022-05-22 15:55:26 +08:00
|
|
|
|
Main.Settings.Username = username;
|
2021-12-14 22:39:15 +01:00
|
|
|
|
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
2022-05-31 09:14:30 +08:00
|
|
|
|
/// Get or set the client's settings.
|
2021-12-14 22:39:15 +01:00
|
|
|
|
/// </summary>
|
2022-05-31 09:14:30 +08:00
|
|
|
|
/// <returns>The client's settings, you should NEVER change settings without notifying the player.</returns>
|
|
|
|
|
public static Settings Settings()
|
2021-12-14 22:39:15 +01:00
|
|
|
|
{
|
2022-05-31 09:14:30 +08:00
|
|
|
|
return Main.Settings;
|
2021-09-26 20:52:23 -06:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|