discord-rpc/examples/button-clicker/Assets/DiscordController.cs

130 lines
3.7 KiB
C#
Raw Normal View History

using UnityEngine;
2017-10-17 13:33:12 -07:00
[System.Serializable]
public class DiscordJoinEvent : UnityEngine.Events.UnityEvent<string> { }
[System.Serializable]
public class DiscordSpectateEvent : UnityEngine.Events.UnityEvent<string> { }
[System.Serializable]
public class DiscordJoinRequestEvent : UnityEngine.Events.UnityEvent<DiscordRpc.DiscordUser> { }
2017-10-17 13:33:12 -07:00
2017-10-14 06:21:35 -04:00
public class DiscordController : MonoBehaviour
{
public DiscordRpc.RichPresence presence = new DiscordRpc.RichPresence();
public string applicationId;
public string optionalSteamId;
public int callbackCalls;
public int clickCounter;
public DiscordRpc.DiscordUser joinRequest;
2017-08-03 09:52:43 -07:00
public UnityEngine.Events.UnityEvent onConnect;
public UnityEngine.Events.UnityEvent onDisconnect;
2017-12-04 15:16:59 -08:00
public UnityEngine.Events.UnityEvent hasResponded;
2017-10-17 13:33:12 -07:00
public DiscordJoinEvent onJoin;
public DiscordJoinEvent onSpectate;
public DiscordJoinRequestEvent onJoinRequest;
2017-08-02 17:52:20 -07:00
DiscordRpc.EventHandlers handlers;
public void OnClick()
{
Debug.Log("Discord: on click!");
clickCounter++;
presence.details = string.Format("Button clicked {0} times", clickCounter);
DiscordRpc.UpdatePresence(presence);
}
2017-12-04 15:16:59 -08:00
public void RequestRespondYes()
{
Debug.Log("Discord: responding yes to Ask to Join request");
DiscordRpc.Respond(joinRequest.userId, DiscordRpc.Reply.Yes);
hasResponded.Invoke();
}
public void RequestRespondNo()
{
Debug.Log("Discord: responding no to Ask to Join request");
DiscordRpc.Respond(joinRequest.userId, DiscordRpc.Reply.No);
hasResponded.Invoke();
}
public void ReadyCallback(ref DiscordRpc.DiscordUser connectedUser)
{
++callbackCalls;
Debug.Log(string.Format("Discord: connected to {0}#{1}: {2}", connectedUser.username, connectedUser.discriminator, connectedUser.userId));
2017-08-03 09:52:43 -07:00
onConnect.Invoke();
}
public void DisconnectedCallback(int errorCode, string message)
{
++callbackCalls;
Debug.Log(string.Format("Discord: disconnect {0}: {1}", errorCode, message));
2017-08-03 09:52:43 -07:00
onDisconnect.Invoke();
}
public void ErrorCallback(int errorCode, string message)
{
++callbackCalls;
Debug.Log(string.Format("Discord: error {0}: {1}", errorCode, message));
}
public void JoinCallback(string secret)
{
++callbackCalls;
Debug.Log(string.Format("Discord: join ({0})", secret));
2017-10-17 13:33:12 -07:00
onJoin.Invoke(secret);
}
public void SpectateCallback(string secret)
{
++callbackCalls;
Debug.Log(string.Format("Discord: spectate ({0})", secret));
2017-10-17 13:33:12 -07:00
onSpectate.Invoke(secret);
2017-10-14 06:21:35 -04:00
}
2017-10-14 06:12:03 -04:00
public void RequestCallback(ref DiscordRpc.DiscordUser request)
2017-10-14 06:21:35 -04:00
{
++callbackCalls;
Debug.Log(string.Format("Discord: join request {0}#{1}: {2}", request.username, request.discriminator, request.userId));
2017-12-04 15:16:59 -08:00
joinRequest = request;
2017-10-17 13:33:12 -07:00
onJoinRequest.Invoke(request);
2017-10-14 06:21:35 -04:00
}
2017-10-14 06:21:35 -04:00
void Start()
{
}
2017-10-14 06:21:35 -04:00
void Update()
{
2017-08-02 17:52:20 -07:00
DiscordRpc.RunCallbacks();
}
2017-10-14 06:21:35 -04:00
void OnEnable()
{
2017-08-02 17:52:20 -07:00
Debug.Log("Discord: init");
callbackCalls = 0;
2017-08-02 17:52:20 -07:00
handlers = new DiscordRpc.EventHandlers();
handlers.readyCallback = ReadyCallback;
handlers.disconnectedCallback += DisconnectedCallback;
handlers.errorCallback += ErrorCallback;
handlers.joinCallback += JoinCallback;
handlers.spectateCallback += SpectateCallback;
2017-10-14 06:21:35 -04:00
handlers.requestCallback += RequestCallback;
DiscordRpc.Initialize(applicationId, ref handlers, true, optionalSteamId);
}
void OnDisable()
{
Debug.Log("Discord: shutdown");
DiscordRpc.Shutdown();
}
void OnDestroy()
{
2017-10-14 06:21:35 -04:00
}
}