Getting Started
Like what you're seeing?
Support us as a GitHub Sponsor and get instant access to all our assets, exclusive tools and assets, escalated support and issue tracking and our gratitude. These articles are made possible by our GitHub Sponsors ... become a sponsor today!
Be sure to read the Installation article, it contains information on initial engine and project configuration that will prevent most "getting started" issues.
Import the Toolkit for Steamworks plugin to your project. Whether you purchased the plugin from Unreal Marketplace or are a GitHub Sponsor you will need access to the Toolkit for Steamworks plugin to get started using it.
The plugin is not free and is only available from Heathen via the GitHub Sponsor program, Patreon and on the Unreal Marketplace. If you acquired the plugin anywhere else we suggest you remove it immediately as it's not a legit copy and likely contains malware.
Configuration
Toolkit for Steamworks works with Steamworks SDK and is compatible with all of Unreal's built-in Steam-related plugins. It uses the same configuration features to keep things simple. This means even if you are not using OnlineSubsystemSteam you will be using its Engine.ini settings to configure and control Toolkit for Steamworks.
App ID
In development, the OnlineSubsystemSteam SteamDevAppId value is used
To define UE_PROJECT_STEAMSHIPPINGID
we use the game's Target.cs, an example from one of our projects follows.
The following is just an example you would use your own settings and the name of your constructor would of course be different. The point is to show you a working example in the Target.cs of your app.
Steam Sockets
You do not have to use Online Subsystem Steam in order to do Steam Networking multiplayer. You will need to include and configure the plugin as that is how the Third Party Steam Shared plugin gets its config. You do not have to use Sessions or Advanced Sessions to work with it either, our tools enable you to use Steam Lobby and other standard Steamworks features as intended by Valve without the confines of Epic's Online Subsystem You can of course if you so wish, use Epic's Online Subsystem concept with Steam ... all options are supported.
We leverage the built-in Steam Socket Net Driver which has a dependency on the Online Subsystem Steam plugin. When you enable Steam Sockets plugin (not just Online Subsystem Steam) the related dependencies should also be enabled and will require a restart of the engine.
Once enabled the following ini settings become relevant ... learn more in Unreal's official documentation
With the plugin installed, you will want to set up your Game Instance.
The plugin ships with a ready-to-use Steam Game Instnace named BP_SteamGameInstance
You can use this as is or use it as a learning tool to create your own Game Instnace derived from our SteamGameInstance parent class or use it as is.
Global Events
Steamworks is largely a multi-process and thus asynchronous toolkit where you will need to listen on events to know when a request has been serviced. In many if not most cases we provide a "Callback" parameter to methods where you can create an event that will be invoked for that specific method call.
In some cases, however, you may wish to bind to the global event
To help you do this we defined all of the global events as delegates on the Steam Game Instance and created a simple Get Steam Game Instance method that will fetch the current instance for you. You can then browse and bind on any events you like, be sure to unbind before the object in question leaves scope as these are global events that remain in scope themselves for the life of your game.
Callbacks
As you should know Steamworks SDK enables your game to ask Steam (the authenticated client on the user's machine) to do stuff for your game. This means it is largely a multi-process and asynchronous thing.
Valve handles this in a classic way using Callback and CallResult delegates. This is translated in Unreal as "Global" events and Function callbacks.
Global Events
You can bind to global events via the Steam Game Instance ... we provide a simple Get Steam Game Instance node to make this easy to "get".
You can then browse and bind on any events you like, be sure to unbind before the object in question leaves scope as these are global events that remain in scope themselves for the life of your game.
Function Callbacks
These take the place of Valve's "CallResult" delegate and are scoped to a specific method call for these you will see there is a delegate parameter on the function call where you can create an event that will be invoked when the request is complete.
Become a Steam Developer and get your own App ID.
Valve does provide a test app ID you can use as a matter of demonstration and our Steam Game Instance will default to its App ID (480) however you will want to register for your own App ID as soon as possible.
You can learn more about getting started as a Steam Developer in our article here!
Builds
If you are building a Dedicated Server you will need to ensure you have the following definitions declared, there are several ways you can go about this such as the Target.cs, please see Unreal Engine's documentation for details.
This is a requirement from the Online Subsystem Steam plugin and deals with how it initializes the Steamworks SDK.
We document it here because it is often overlooked, to find the source documentation please review the Server Details section of the Online Subsystem Steam article on Epic's documentation site.
You can use your game's Target.cs to set these values using the GlobalDefitnions list.
UE_PROJECT_STEAMPRODUCTNAME
STEAMPRODUCTNAME
Typically your App ID Used by Steam Game Server Matchmaking features.
UE_PROJECT_STEAMGAMEDIR
STEAMGAMEDIR
This should be the folder where your game resides and is usually just the game name sans spaces and symbols. note it's just the folder name, not the path it's self
UE_PROJECT_STEAMGAMEDESC
STEAMGAMEDESC
Usually the human name of your game
UE_PROJECT_STEAMSHIPPINGID
This is 100% Unreal Engine and is used in both client and server when not in the editor or a Dev build. It is simply your App ID and is used during initialization.
steam_appid.txt
We have a full article on what this text file is and when you should or should not be using it. Epic notes are similar in their article here.
In short, this should only be needed when your running a packaged project from outside of Steam or if your running a Dedicated server build.
Use the kit
The Example Level presents a UI that demonstrates key features
Be sure to check out the Graph on the BP_Example_UI for additional examples such as how to find, join and create a Steam Lobby, Host and Join a network session via Steam Networking Sockets, etc.
The Center Bottom text boxes are used to test lobby and multiplayer features.
Lobby
You can create a lobby by clicking the button with the input field empty.
You can join a lobby by typing in the Hex ID of the lobby you wish to join.
Browsing and matchmaking can also be done with blueprint nodes only, we simply didn't want to clutter the example with to many use cases.
Multiplayer
Everything in the example scene is done with Blueprint Nodes requiring no C++ work at all. The UI WIdgets used are all created using Blueprint Nodes only again no C++ work required at all.
Features
Be sure to see the Steamworks Guide and its sub-articles for more detail, follows is a quick list of major features you will find.
Achievements
API
Authentication
Cloud Save
Debugging
Downloadable Content
Friend List
Input
Inventory
Item Store
Leaderboards
Lobby
Matchmaking
Microtransactions
Multi-Platform Project
Multiplayer
Rich Presence
Room Systems
Running a Build
Steam Game Server
steam_appid.txt
Steam ID
Stats
User Information
Voice
Workshop
Beyond samples we have extensive documentation including how-to guides for nearly every aspect of the Steam platform, going beyond simple documentation for our tools and assets. You can learn more about all the features of Steam in our knowledge base by reviewing the hundreds of articles linked in the navigation panel to the left ๐
If you have any questions simply look up ... there you will find our Search tool which is AI-assisted and fairly useful as well as links to our Discord Community where you can get live support.
Troubleshooting
Package Closes/Crashes on launch
This happens when you run a package that has not been deployed by the Steam client. You will find that the Should Restart event if you simply copied the example implementation closes the app if it has not been launched from the Steam client.
You can prevent this check by adding a steam_appid.txt to the root of your project as shown in the image below
DO NOT ship your game with steam_appid.txt this bypass is meant for devs.
You DO want your game to shut down and relaunch from the Steam client to ensure the Steam API works properly in every other use case.
Learn more about steam_appid.txt and when to and when not to use it.
Editor Crash on Play
Where the crash log mentions an Access Violation or similar low-level exception noting the steam_api.dll or a similar Steam-related assembly.
Typically caused by an issue with the Steam Shared plugin. This is a built-in plugin of the Unreal engine not part of Heathen's codebase but is a dependency. If you attempted to update Steamworks SDK or made some change to the engine build that prevents the Steam Shared plugin from loading properly you will get this sort of crash.
To correct the issue start by verifying your engine install, if you are building from source check for compilation errors and changes to the Third Party Steamworks engine plugin. If you installed via the launcher you can simply right-click on the engine version and select Verify, it will clean and correct any issues found.
Callbacks are not working in the package
In most cases, this is due to Steam API not initializing,
In most cases, with a package, this is due to you running the package without deploying it from the Steam client without using the steam_appid.txt and without properly handling the Restart Required case.
When you run the package Steam API will perform a check known as "Restart Required" This checks to see if the app was run from the Steam client, if it was not it will attempt to re-launch the game from the Steam client.
If you are just getting started however your game won't have launch options in the Steam client so that will do nothing.
In addition, Steam API will not have initialized and will not be processing callbacks e.g. Steam API is simply not working in that case.
You can sidestep the Restart Required check by using the steam_appid.txt, please read and understand what steam_appid.txt is before you use it.
The Game Doesn't Stop (in the editor)
When you run your game in the editor, the editor's process (as far as Steam is concerned) is your game, so it will show it as "playing" as long as the Editor remains open. Attempting to force it to stop may close your editor unexpectedly or cause an Editor crash.
It doesn't hurt anything for Steam to see the Unreal Editor process as your game so you can simply ignore this.
If it bothers you, you can run the simulation as a Standalone Process from the editor, as this is its own process Steam will properly see it start and stop and the Overlay will work properly. Keep in mind if you have already ran in the editor you may need to restart the editor to get Steam to let go of that old initialization.
Overlay Doesn't Work
Your probably running the simulation in the editor as opposed to as a separate process. The Steam Overlay works by finding the window handle of the window process that initialized it. When your running the simulation as part of the Editors process you will have issues with Overlay because Unreal Editor has a great many window handles most of which do not update every frame and so Steam Overlay just doesn't work properly.
If you run your app as a Standalone Process Overlay should work for you, though if you have already initialized in the editor you may need to restart to clear that initialization. See my game doesn't stop when I stop the simulation.
On Launch 2 Windows Open
You are running your package without having deployed it from the Steam client.
You have configured launch options for your app
You are not handling the Restart Required case properly.
When you run the package Steam API will perform a check known as "Restart Required" This checks to see if the app was run from the Steam client, if it was not it will attempt to re-launch the game from the Steam client.
In addition, Steam API will not have initialized and will not be processing callbacks e.g. Steam API is simply not working in that case.
You can sidestep the Restart Required check by using the steam_appid.txt, please read and understand what steam_appid.txt is before you use it.
Last updated