# Unreal Engine Quick Start

This guide will show you how to integrate the Frameplay plugin into your Unreal Engine project.

We officially support:

  • Unreal Engine versions: 4.23 to 5.4
  • Platforms: Windows, Android

# Prerequisites

To get started you must first have created:

# Getting Started

# Download and Install the Frameplay Unreal Engine Plugin

  1. Download and unzip the Frameplay folder from our downloads page (opens new window)
  2. Navigate to your Unreal Engine project root directory (this folder contains the .uproject file)
  3. Create a Plugins folder
  4. Copy the downloaded Frameplay folder into the Plugins folder

# Generate Visual Studio Project Files for Code Projects

If you are using a Code Project you must generate Visual Studio files. If you are using a Blueprint Project please skip this step.

  1. Right click the project's .uproject file
  2. Select "Generate Visual Studio project files"

Image

See Project Files for IDEs (opens new window) for more information on generating Visual Studio project files.

# Enable the Frameplay Plugin

Confirm the Frameplay plugin was successfully installed into your project.

  1. Launch the Unreal project
  2. Navigate to Edit > Plugins
  3. Confirm the Frameplay Plugin is enabled

Image

See Plugins in Unreal (opens new window) for more information on Plugins inside of Unreal Engine.

# Configure Project Name and Version

Confirm your Project Name and Version have been entered into the Project Settings.

  1. Navigate to Edit > Project Settings
  2. Select Project > Description
  3. Enter your Project Name and current Project Version

Image

# Configure the Frameplay Developer Settings

The Frameplay Developer Settings are used to maintain the link between your Unreal project and the Developer Dashboard.

  1. Select the Frameplay Toolbar icon > Developer Settings

Image

  1. Enter the Developer API Key and Game ID with the corresponding values found on your Game Page (opens new window)

Image

Find out more about the Developer Settings here

# Initialize the Frameplay SDK

  1. Initialize the Frameplay SDK by calling the method: UFrameplayFunctionLibrary::Start_Session(). This will create a secure runtime connection to the Frameplay servers.
  2. Configure the player parameter with the current player details. (If available, the players Age and Gender should be passed as parameters. These can be sourced from a client API or a custom login)
  3. Set the Allow Data Collection player parameter. This corresponds to the respective platform signal Limit Ad Tracking.

# Blueprint Example

Image

The Frameplay Session requires knowledge of the active Camera to use for measuring viewability. More information on Registered Cameras

# Code Example

# Header File
// EXAMPLE HEADER FILE (.h)

#pragma once

#include "CoreMinimal.h"
#include "GameFramework/Actor.h"
#include "Frameplay/frameplay_wrapper.h"
#include "AExampleInit.generated.h"

UCLASS()
class UNREALPROJECT_API AAExampleInit : public AActor
{
    GENERATED_BODY()

public:
    // Sets default values for this actor's properties
    AAExampleInit();

protected:
    // Called when the game starts or when spawned
    virtual void BeginPlay() override;
    virtual void EndPlay(const EEndPlayReason::Type EndPlayReason) override;
};
# Source File
// EXAMPLE SOURCE FILE (.cpp)

#include "AExampleInit.h"
#include "FrameplayFunctionLibrary.h"

// Sets default values
AAExampleInit::AAExampleInit()
{
    // Set this actor to call Tick() every frame.  You can turn this off to improve performance if you don't need it.
    PrimaryActorTick.bCanEverTick = true;
}

// Called when the game starts or when spawned
void AAExampleInit::BeginPlay()
{
    Super::BeginPlay();

    //Capture player data
    const FPlayer_Data Player{UData_Collection::allow, 20, EFrameplayGender::unknown, "en", "newPlayer"};

    //Start SDK
    UFrameplayFunctionLibrary::Start_Session(Player);
}

void AAExampleInit::EndPlay(const EEndPlayReason::Type EndPlayReason)
{
    Super::EndPlay(EndPlayReason);
    UFrameplayFunctionLibrary::Shutdown_Session();
}
# Build.cs File

The Build.cs file controls access to Unreal Engine modules and can be found here: [PROJECT_ROOT]/Source/[PROJECT_NAME]/[PROJECT_NAME].Build.cs. You will need to add Frameplay as a public dependency.

// EXAMPLE BUILD.CS FILE (.Build.cs)

using UnrealBuildTool;

public class UnrealProject : ModuleRules
{
    public UnrealProject(ReadOnlyTargetRules Target) : base(Target)
    {
        PCHUsage = PCHUsageMode.UseExplicitOrSharedPCHs;

        // We add "Frameplay" to the end here!
        PublicDependencyModuleNames.AddRange(new string[] { "Core", "CoreUObject", "Engine", "InputCore", "Frameplay" });
    }
}

More information on Frameplay Sessions

More information on the Frameplay API.

# Create an Ad Space

An Ad Space is an Actor that displays intrinsic advertisements to the player. They can be created through the editor Place Actor menu or in a Blueprint.

  1. Using the Place Actors Mode, drag and drop a Frameplay Ad Space Actor into the Viewport
  2. Reposition and scale the Ad Space to fit your environment.

Image

# Configure an Ad Space

  1. Select the Ad Space in the World Outliner to view it in the Details panel
  2. Enter a unique name for the Ad Space
  3. Select your preferred ratio to best fit your environment
  4. Optional: select Synchronize Ad Space and enter a Channel Name to begin creating a group of Synchronized Ad Spaces that render the same advertisement.

Image

# Load a Mock Advertisement

Begin Play In Editor Mode. This will trigger the Frameplay session to start and load a mock advertisement.

Image

Congratulations! You have created your first intrinsic advertisement.

# View Impression Data

Sessions started in-editor and in development builds will automatically run in Test Mode. This means that only mock advertisements will be displayed.

Impression data gathered in Test Mode will display on your games Test Dashboard (opens new window).

Image

# Packaging Builds

Before monetizing your final build, you must first submit your account and game for approval on the Frameplay Platform:

Please allow 48 hours for approval. Advertisements will not load in Production builds until both your account and game is approved.

To package a final build:

  1. Select File > Package Project > Build Configuration.
  2. Confirm Shipping mode is selected.

At this time our integration team will contact you and notify once approved.

# Best Practices

We highly recommend you check out the Best Practices Guide to maximize revenue, impression quality and user experience!

# Troubleshooting

If something went wrong along the way, check the console for logs and visit our FAQ.

Last Updated: 7/15/2024, 11:21:52 PM