Skip to content

Latest commit

 

History

History
235 lines (161 loc) · 11.8 KB

File metadata and controls

235 lines (161 loc) · 11.8 KB

Discord Plugin for Unreal Engine ( Blueprint Integrated )

Unreal Engine Plugin for Discord Rich Presence Integration with Blueprints

Any Doubts or Issues: Reach me out on Discord @Jaizxzx

This plugin is based on Discord GameSDK v3.2.1. and this plugin is based on the Xist's DiscordGameSample.

The Unreal Engine version used is UE 5.3.2 .

To see this in action, build and run the game. As soon as the game (or UEditor) starts, if you have Discord running on your machine, your Discord status will be updated to show that you're running the game.

How to Use the DiscordGame Plugin in your Game

  • Update the SDK to the latest (see Updating Discord GameSDK)

  • Copy the entire Plugins/DiscordGame folder into your project

  • Add DiscordGame to PublicDependencyModuleNames in your Build.cs

  • Create your own Custom DiscordGame-derived Subsystem

    • Use UMyDiscordGameSubsystem { h | cpp } as a starting point (replace it with your own subsystem or modify it to your needs)
  • create a c++ class derived from DiscordGameSubsystem.

  • you can modify the UMyDiscordGameSubsystem for your game or just copy paste the code However modify the Client Id ( Client Id is used in unreal and discord calls it Application Id) for your application follow the Setting up the Discord Developer Portal Application below to get the Application Id.

  • You have to add this application id in the constructor of the MyDiscordGameSubsystem as ClientId = Your_Application_Id_Here

  • Now compile the code and launch the Unreal Engine from Visual Sutdio and Do this in the level blueprint

    Example Screenshot

  • Add whatever gameplay hooks you want, you're now online with Discord's Rich Presence!

  • If everything goes well you will see something like this

    Example Screenshot

  • Note : If you want to set and get the application id (client id in unreal engine) from the ini then copy the below text in your DefaultGame.ini file found in Your_Project_Directory/Config :

[/Script/DiscordGame.DiscordGameSubsystem]
ClientId=Your_Application_Id
CreateRetryTime=5.0

Setting up the Discord Developer Portal Application

  • To get the custom image for your game or application on discord and to connect to the discord rich presence we need to follow the below steps:
  1. Go to Discord Dev Portal
  2. Create an Application by clicking on the New Application on top right corner give it a name proceed
  3. Copy the Application ID from the application general info
  4. Go to the rich presence/art assets and upload a icon or picture you want to set for the application while running it.
  5. Copy the name of the picture as it wil be used to set the picture or modify while running the game.

Facing Issues ?

If you are facing issues with the given example project in the repo then follow the below steps and configure discord_game_sdk for your system and UE version.

DiscordGame Plugin

The primary point of interest in this repository is the DiscordGame plugin, which contains 2 modules:

DiscordGame Module

DiscordGameSDK ThirdParty Module

  • ThirdParty Module containing Discord GameSDK distributable DLLs

Custom Discord Game Subsystem

  • Intended to be modified for your own custom implementation.

The underlying UDiscordGameSubsystem does all of the actual work of loading the SDK and managing the connection to the DiscordCore, but it doesn't actually implement any gameplay behavior.

The UMyDiscordGameSubsystem { h | cpp } is an example of the kind of custom subsystem you can make for your game, where you will implement whatever behavior you want.

In this case, it automatically sets the Discord Rich Presence as soon as we're able to connect to Discord, and it unsets it when the game ends.

Note that you should completely replace UMyDiscordGameSubsystem in your game with whatever custom subsystem you want.

Setup Part 1: Installing the SDK

Current Discord GameSDK version: v3.2.1

I downloaded Discord GameSDK from https://dl-game-sdk.discordapp.net/3.2.1/discord_game_sdk.zip

It unzips into a directory named discord_game_sdk, and I then ran the following PowerShell commands to copy it into the appropriate place into this DiscordGameSample UE project:

# Copy the binaries from the SDK "lib" dir i.e discord_game_sdk/lib/ to "DiscordGameSDK" Source dir i.e Plugins/DiscordGame/Source/ThirdParty/DiscordGameSDK/

# Copy the entire "cpp" dir i.e discord_game_sdk/cpp from the SDK to the "discord-cpp" Source dir i.e Plugins/DiscordGame/Source/DiscordGame/discord-cpp

I recommend that before you run this, you replace the files in the directories above with the latest versions that you yourself downloaded from Discord.

If there is no newer version of Discord GameSDK or Unreal Engine ( as compared to the one used for the project i.e UE 5.3.2 ), then you can use the binaries I committed to this repository inside the sample.

I am not responsible for your computer melting down or any other things that may happen as a result of you executing binaries that you downloaded from the Internet. So better you compile new binaries instead by following the steps.

Setup Part 2: Exporting the SDK

After you install the latest SDK, you also need to export all of the classes so you can use them in other UE5 modules.

You can do this manually, however there is a simple PowerShell script and if you face any errors read the warning carefully if it is a trust error then the powershell will give the corrected command to run it in the error and if it is a microsoft limitation or script permission error then just google it, it is an easy fix. (ExportGameSDK.ps1) to automate this process.

Note: Run the powershell in administrator mode and if you face any errors read the warning carefully if it is a trust error then the powershell will give the corrected command to run it in the error itself and if it is a microsoft limitation or script permission error then just google it, it is an easy fix.

To run it for real and modify the Discord GameSDK C++ headers, run it like:

ExportGameSDK.ps1

You can also execute ExportGameSDK.ps1 in a debug test mode such that it will not make any modifications, and instead will only show you what it would really do:

ExportGameSDK.ps1 -Debug -DryRun

Example output from -Debug -DryRun

-Debug -DryRun Terminal Screenshot

(The actual output is a few screen lengths)

Possible Compilation (Linker) Errors

If you fail to export the SDK's C++ classes, when you try to use them in your own UE5 module, during compilation you will see linker errors such as this:

LNK2019: unresolved external symbol "public: void __cdecl discord::ActivityAssets::SetLargeImage(char const *)" (?SetLargeImage@ActivityAssets@discord@@QEAAXPEBD@Z) referenced in function "public: bool __cdecl UCustomDiscordGameSubsystem::UpdateActivity(void)" (?UpdateActivity@UCustomDiscordGameSubsystem@@QEAA_NXZ)
LNK2019: unresolved external symbol "public: class discord::PartySize & __cdecl discord::ActivityParty::GetSize(void)" (?GetSize@ActivityParty@discord@@QEAAAEAVPartySize@2@XZ) referenced in function "public: bool __cdecl UCustomDiscordGameSubsystem::UpdateActivity(void)" (?UpdateActivity@UCustomDiscordGameSubsystem@@QEAA_NXZ)
LNK2019: unresolved external symbol "public: void __cdecl discord::Activity::SetState(char const *)" (?SetState@Activity@discord@@QEAAXPEBD@Z) referenced in function "public: bool __cdecl UCustomDiscordGameSubsystem::UpdateActivity(void)" (?UpdateActivity@UCustomDiscordGameSubsystem@@QEAA_NXZ)
LNK2019: unresolved external symbol "public: class discord::ActivityManager & __cdecl discord::Core::ActivityManager(void)" (?ActivityManager@Core@discord@@QEAAAEAV02@XZ) referenced in function "public: void __cdecl UCustomDiscordGameSubsystem::ClearActivity(void)" (?ClearActivity@UCustomDiscordGameSubsystem@@QEAAXXZ)

To fix these errors, execute ExportGameSDK.ps1 and compile again.

Setup Part 3: Silence UE5 Build Warnings

An optional (recommended) setup step is to silence the UE5 Win64 build warnings regarding the use of strncpy.

The build will work without this step, but IMO it is annoying to see 20+ warnings every time you build.

The fix is easy. You need to copy/paste 5 lines of code into types.cpp, which we previously copied into the discord-cpp directory from the SDK zip extraction.

//~Begin UE5 change
#ifdef _MSC_VER
#pragma warning(disable:4996)  // Disable warning: Function 'strncpy' is deprecated
#endif
//~End of UE5 change

Paste the above code in the top of the file types.cpp .

What are these Compilation Warnings

The warnings look like this:

0>types.cpp(24): Warning C4996 : 'strncpy': This function or variable may be unsafe. Consider using strncpy_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. See online help for details.

These warnings are due to Discord GameSDK being ultimately written in C and using old C memory copy methodologies, which is generally not something you want to do in a modern C++ project.

This isn't really a problem as Discord has taken care to ensure that buffer overruns won't actually result from using these methodologies. You can safely ignore these warnings.

Setup Part 4: Use UE5-safe Windows.h

UE5 does not like to use <Windows.h> without a wrapper.

Discord does use <Windows.h> and so it is preferred to modify that include to use the UE5 WindowsHWrapper.h instead.

This is a relatively trivial change, but it is required to modify 2 files to effect it.

There are 2 required modifications:

  • In header discord-cpp/ffi.h
    • DO NOT include Windows.h, instead include Windows/WindowsHWrapper.h
    • DO include ole2.h, which we need.
    • #define COM_NO_WINDOWS_H 1 for dxgi.h
      • This causes dxgi.h to NOT include Windows.h, which we want.
      • It also causes dxgi.h to NOT include ole2.h, but we do need ole2.h, which is why we now explicitly include it.

text #include "Windows/WindowsHWrapper.h" #include "ole2.h" #define COM_NO_WINDOWS_H 1 // Tell dxgi.h DO NOT include Windows.h (or ole2.h; which we explicitly included above)

  • In header discord-cpp/types.h
    • DO NOT include Windows.h or dxgi.h
      • These are both already included by discord-cpp/ffi.h
      • Rather than apply the same fix here as we did to discord-cpp/ffi.h, we just remove these duplicate includes.