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

113 lines
2.9 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.JoinRequest> { }
2017-10-14 06:21:35 -04:00
public class DiscordController : MonoBehaviour
{
public DiscordRpc.RichPresence presence;
public string applicationId;
public string optionalSteamId;
public int callbackCalls;
public int clickCounter;
2017-08-03 09:52:43 -07:00
public UnityEngine.Events.UnityEvent onConnect;
public UnityEngine.Events.UnityEvent onDisconnect;
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(ref presence);
}
public void ReadyCallback()
{
++callbackCalls;
Debug.Log("Discord: ready");
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
2017-10-14 06:21:35 -04:00
public void RequestCallback(DiscordRpc.JoinRequest request)
{
++callbackCalls;
Debug.Log(string.Format("Discord: join request {0}: {1}", request.username, request.userId));
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
}
}