Game Foundation Tutorials
Working with Promotion Pop Up prefab
This tutorial will show how to use the Promotion Popup prefab and component to advertise a transaction that you would like to display as a special offer, like a starter pack, for example.
The image above shows the prefab displaying a sample starter pack promotion. The prefab has two options for the main promotion image: to display an image you supply, or to auto-generate one based on the rewards in the transaction. This sample starter pack is using an auto generated image.
The promotion prefab is designed to be flexible, allowing you to swap in your own images and layouts to make the pop up look like one that is native to your game. However, the component supplied with the prefab could also be attached to a prefab of your own design, and would handle getting the images and data to display from the transaction for you.
Finding the prefab and component
If it hasn't been already, the Game Foundation prefab package can be imported by going to Window -> Game Foundation -> Import Prefabs and Samples
.
This will add a folder called Game Foundation Prefabs
into your Assets folder.
Inside this folder you'll find all our UI Prefabs in the UI Prefabs folder, and sample scenes for how to work with them in the Samples folder.
The Promotion Popup prefab in particular can be found in Game Foundation Prefabs/UI Prefabs/Store/Promotion
.
You can drag it into your scene from there to customize.
The components that are used by these prefabs (or available to be used by your own custom prefabs) are located in the Game Foundation package inside the Components
folder.
Breaking down the prefab and component
Header
The header of the prefab has popup title and close button.
The popup title is filled in using the display name of the selected transaction.
The text field where you want the name to be filled in is linked to the component in the Title Text Field
in the Texts section.
Also in the header of the prefab is the close button.
This can be reskinned to look however you would like in your game.
By default it is linked to the component's Close
method, which sets the prefab's active state to false, and triggers the On Popup Closed
callback.
Description
To set the text that you want to be displayed in the promotion description, you'll define static property key
and string value
for the transaction you want to display in the promotion.
Then, in the Promotion Popup View component, select the key you defined in the Description Property Key
field.
The text field where you want the property's value to be filled in is linked to the component in the Description Text Field
in the Texts section.
Promotion Pack Image
The promotion pack image section of the prefab is made up of two parts, the promotion image area and the badge.
Badge
The badge can be used to include a special callout about the promotion.
The text for the badge is specified in the transaction's static property, just like the promotion description, and selected in the Badge Text Property Key
dropdown of the component.
The text field where you want the badge text to be filled in is linked to the component in Badge
in the Texts section.
Promotion Image Area
The promotion image area is where the image that showcases all the benefits the user will get from purchasing goes. There are two options for filling this image in: by supplying the image yourself, or by letting the prefab auto generate an image for you.
If you want to supply the image yourself:
- Uncheck
Auto Generate Promo Image
in the Promotion Popup component - Add the image to the transaction's static properties as a Resources Asset
- Set the
Promo Image Property Key
field in the component to match the key designated in the previous step The GameObject where you want the image displayed should be set in thePromo Image Field
.
If you want to have the prefab auto generate the image for you:
- Check
Auto Generate Promo Image
in the Promotion Popup component - Make sure each item or currency added as a reward in the transaction have an image added in their static properties as a Resources Asset, using the same key for each.
- Set the
Payout Item Icon Property Key
to the key used in the previous step - Specify whether you want a prefix for when the image displays the count of each item, by default an
x
is used but this can be changed, or, if the field is left blank, no prefix will be used - Specify whether you want a prefix for when the image displays the count of each currency, by default an
x
is used but this can be changed, or, if the field is left blank, no prefix will be used - The game object where you want the image generated should be set in the
Promo Image Container
. - The Payout Item Prefab is used to arrange the payout image and count for easy adding of each transaction payout. Basic Payout Item prefabs can be found in
Game Foundation Prefabs/UI Prefabs/Store/Payout Items/
. The one used by default in the Promotion Popup Prefab is theVertical Payout Item
however you could customize your own for a different look. - The Separator Prefab will be used in between each Payout Item Prefab that is generated. In the image above you'll see a simple separator prefab was used to add the
+
in between each payout. By default no separator prefab is used by the component, however you can find the one we used in that image inGame Foundation Prefabs/Samples/02_Promotion Popup
.
Purchase Button
The Promotion Popup uses the Purchase Button prefab also used by the Store prefabs and first described in the Working with Store Prefabs tutorial.
The Promotion Popup component also has a field for specifying what key to use for looking up the cost image to display on the purchase button, if the cost is a virtual currency or item.
You can select which key to use in the Price Icon Asset Property Key
dropdown.
In case you want to use your own Purchase Button, you can change what prefab to use in the Purchase Button field of the component (whichever prefab you set, it must have the PurchaseButton component attached).
By default, the prefab is configured to call the component's close method if the Purchase Button OnTransactionSucceeded callback is triggered (i.e. the prefab will close automatically after a successful purchase). Should you want a different behavior after a successful purchase, you can remove the Close method from the list of On Transaction Succeeded listeners.
Working with the Promotion Popup Component API
The main ways you'll interact with the Promotion Popup component's API is in calling the open and close methods.
Additionally, there are setter methods for changing any of the fields on the component. These can be used to change how the prefab is displayed at runtime, including which transaction is displayed.
Finally there is a host of callbacks you may want to subscribe to for knowing when the popup is about to open or close, has just finished opening or closing, or whether a purchase has successfully completed, or attempted to be completed and failed.
Conclusion
We hope this prefab will help to provide a simple and easy way for adding a promotion to your game. In the next section you'll learn about additional tools for configuring your game.