PubNub Unreal SDK 0.1.0
This page outlines the steps to follow to create a simple application with PubNub. This covers the basics of integrating PubNub in your application: setting up a connection to PubNub, and sending and receiving messages.
Interactive Blueprints
This sample app is based on Blueprints.
You can copy any interactive Blueprint you find in the PubNub Unreal SDK documentation and paste it into your Unreal Editor's Blueprint editor.
PubNub account
Sign in or create an account to create an app on the Admin Portal and get the keys to use in your application.
When you create a new app, the first set of keys is generated automatically, but a single app can have as many keysets as you like. We recommend that you create separate keysets for production and test environments.
Configure Unreal Engine
-
Download and install Unreal Engine version 5.0 or higher.
-
Create a new blank Unreal project in a location of your choice.
-
Create an empty
Plugins
folder in your Unreal project's location.
Download the SDK
In the Plugins
folder of your Unreal project:
-
Clone the content of the Unreal SDK repository: https://github.com/pubnub/unreal-engine.
-
Change the folder name in which you cloned the content to
Pubnub
.
Configure the workspace
-
In the project's root folder, right-click the
projectname
.uproject
file and, depending on your operating system (OS), select:OS Selection MacOS Services -> Generate xCode project Windows Generate Visual Studio project files -
Wait until the files are generated and open your OS-specific workspace.
-
In your IDE, navigate to
Source/_{YourProject}_/_{YourProject}_.Build.cs
and add a dependency toPubnubLibrary
.PrivateDependencyModuleNames.AddRange(new string[] { "PubnubLibrary" });
-
Compile the code and run the project.
Configure the Unreal Engine project
-
In Unreal Engine, create necessary classes like:
Component Description GameMode
Controls the game’s rules and flow. PlayerController
(Widget)Manages players' inputs and the characters they control. PlayerPawn
Represents the player’s character in the game world. GameInstance
Handles data and logic across map transitions and beyond the lifetime of any single level. Level
Contains your game world. Widget
Manages user interfaces like menus or HUD elements. -
In Project Settings, on the Maps and Modes tab, specify the correct default
GameMode
andGameInstance
.Default classes
Maps and Modes is where you define what classes your project will use by default. This ensures that your custom classes are used when the game starts, which is fundamental for accessing your custom logic and settings.
-
In the Default Modes section, change Player Controller Class and Default Pawn Class to the created ones.
Default modes
You need to link your custom
PlayerController
andDefaultPawn
classes to theGameMode
so that when the game starts, these specific classes will be used for the player character and their controller, providing custom functionalities. -
In the
PlayerController
Blueprint, create and add the widget to the viewport. Make sure to changeGettingStarted_C
to the widget you created.
For more information on Unreal Engine basics, refer to the Unreal Engine documentation.
Configure PubNub SDK
The minimum configuration to send and receive messages with PubNub are setting the Publish Key and Subscribe Key.
-
In the Unreal Editor window, click the Settings dropdown and select Project Settings.
-
In the Project Settings window, scroll down to the Plugins section and click Pubnub SDK.
-
In the Plugins - Pubnub SDK view, provide the desired values for the available configuration options.
For more information, refer to the Configuration section of the SDK documentation.
Create user interface
In your widget Blueprint, open the Designer view and paste the following code. This adds the UI elements we will use to publish and subscribe.
Begin Object Class=/Script/UMG.CanvasPanel Name="CanvasPanel_20" ExportPath=/Script/UMG.CanvasPanel'"/Game/UI/GettingStarted.GettingStarted:WidgetTree.CanvasPanel_20"'
Begin Object Class=/Script/UMG.CanvasPanelSlot Name="CanvasPanelSlot_1" ExportPath=/Script/UMG.CanvasPanelSlot'"/Game/UI/GettingStarted.GettingStarted:WidgetTree.CanvasPanel_20.CanvasPanelSlot_1"'
End Object
Begin Object Class=/Script/UMG.CanvasPanelSlot Name="CanvasPanelSlot_0" ExportPath=/Script/UMG.CanvasPanelSlot'"/Game/UI/GettingStarted.GettingStarted:WidgetTree.CanvasPanel_20.CanvasPanelSlot_0"'
End Object
Begin Object Name="CanvasPanelSlot_1" ExportPath=/Script/UMG.CanvasPanelSlot'"/Game/UI/GettingStarted.GettingStarted:WidgetTree.CanvasPanel_20.CanvasPanelSlot_1"'
LayoutData=(Offsets=(Left=309.186951,Top=39.039036,Right=627.271667,Bottom=263.185425),Anchors=(Minimum=(X=0.500000,Y=0.018519),Maximum=(X=0.500000,Y=0.018519)),Alignment=(X=0.500000,Y=0.000000))
End Object
Begin Object Name="CanvasPanelSlot_0" ExportPath=/Script/UMG.CanvasPanelSlot'"/Game/UI/GettingStarted.GettingStarted:WidgetTree.CanvasPanel_20.CanvasPanelSlot_0"'
LayoutData=(Offsets=(Left=-0.750781,Top=15.015015,Right=625.770142,Bottom=293.215454),Anchors=(Minimum=(X=0.500000,Y=0.500000),Maximum=(X=0.500000,Y=0.500000)),Alignment=(X=0.500000,Y=0.500000))
bAutoSize=True
Parent=/Script/UMG.CanvasPanel'"CanvasPanel_20"'
Content=/Script/UMG.VerticalBox'"VerticalBox_74"'
End Object
Slots(0)=/Script/UMG.CanvasPanelSlot'"CanvasPanelSlot_0"'
show all 133 linesThe UI has three input fields and three buttons that allow you to set the User ID, subscribe to a channel, and to publish a message to the same channel.
Add logic with Blueprints
Now it's time to configure what happens when a user clicks any of the buttons. We will be using Blueprints to add PubNub logic to your application.
Set User ID
To add the logic of setting the User ID, open the Graph view and add the following nodes to your Widget
Blueprint.
These nodes also print out the User ID in the output log when it's set.
Publish
Add the following nodes to your PlayerController
Blueprint to add the publishing logic.
The publish functionality uses the same channel name input field used to subscribe.
Subscribe
To receive messages sent to a particular channel, you subscribe to it. When you publish a message to a channel, PubNub delivers that message to everyone subscribed to that channel.
In this app, publishing a message is triggered when you click the Publish Message button.
To subscribe, you must create the Subscribe to Channel node and bind an OnMessageReceived event to it.
For more information, refer to the Publish and Subscribe section of the SDK documentation, and to Publishing a Message.
Putting it all together
Your Blueprint should now look similar to the one below:
Now, run your app and see if you did everything correctly:
-
Click the Set User ID button and provide a channel name in the channel name input field.
-
Click the Subscribe button. You can see
Subscribed to: {channel name}
in the output log and on the screen. -
In the Message to publish input field, provide a message in JSON format, for example:
{ "text" : "This is my first realtime message!" }
and click Publish Message. You can seeMessage published!
andMessage received:{ "text" : "This is my first realtime message!" }
in the output log and on the screen.
Congratulations! You've just subscribed to a channel and sent your first message.
Next steps
You have just learned how to use the Unreal SDK to send and receive messages using PubNub. Next, take a look at the SDK's reference documentation which covers PubNub API in more detail.