Skip to content

pkucherov/HuaweiAdsUnrealPlugin

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

9 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Ads Kit (HMS)

Service Introduction

HUAWEI Ads Kit leverages Huawei devices and Huawei's extensive data capabilities to provide you with the Publisher Service, helping you monetize traffic. Meanwhile, it provides the advertising service for advertisers to deliver personalized campaigns or commercial ads to Huawei device users.The video on this page introduces traffic monetization through HUAWEI Ads Kit and the process for advertisers to display ads.You can click here to watch the MOOC video about Ads Kit.

HUAWEI Ads Publisher Service

HUAWEI Ads Publisher Service is a monetization service that leverages Huawei's extensive data capabilities to display high quality ad content in your apps to the vast user base of Huawei devices.

We offer a range of ad formats including Banner Ads, Native Ads, Rewarded Ads, Interstitial Ads, Splash Ads, and Roll Ads so you can choose whichever that suits your app best. You can use the HUAWEI Ads SDK to integrate HUAWEI Ads into your app. Once you have chosen an ad format, you are ready to start bringing in revenue using our high-quality advertising services.

We also offer the Publisher Service Reporting API for you to obtain traffic monetization report data, including the number of ad requests, number of returned ads, click-through rate, and impression rate.

Identifier Service

Ads Kit provides the open advertising identifier (OAID) and install referrer capabilities for advertisers to deliver personalized ads and attribute conversions.

  • An OAID is a non-permanent device identifier. You can use OAIDs to provide personalized ads for users while protecting their privacy. In addition, third-party tracking platforms can provide conversion attributions for advertisers based on OAIDs.

  • You and advertisers can obtain app install referrers through APIs provided by Huawei. Advertisers can use install referrers to attribute conversions to different promotion channels.

Use Cases

  • HUAWEI Ads Publisher Service

    HUAWEI Ads offers a range of ad formats, as listed in the following table, to best suit your app's requirements in various scenarios.

    Ad Format
    Ad Type Description
    Banner Ads Image A banner ad is presented as a bar or block at the top, middle, or bottom of the screen within an app with high visibility for users who use the app regularly or for a long time.
    Native Ads Image or video A native ad fits seamlessly into the surrounding content to match your app design.
    Rewarded Ads Video A rewarded ad is displayed when a user achieves a level, gets respawned, obtains items, bonus points, or opportunities to continue, or upgrades skills in a game.
    Interstitial Ads Image or video An interstitial ad is displayed when a user starts, pauses, loads, or exits a game or streaming media, achieves a game level, or is redirected in a game or streaming media.
    Splash Ads Static image, GIF image, or video A splash ad is displayed in full screen for 3s immediately when an app is launched. Then the ad will be automatically closed and the app home screen will be displayed.
    Roll Ads Image or video Pre-roll: displayed before the video content.Mid-roll: displayed in the middle of the video content.Post-roll: displayed after the video content or several seconds before the video content ends.
  • Identifier service

    The identifier service can be used by the advertising platforms, developers, third-party tracking platforms, and advertisers in different scenarios. For details, please refer to Use Cases.

Integrating into Your Unreal Project

Register and get verified

Before doing this step, you need to create an HMS Account, project and App according to the HMS document.

Screenshots/Step1.png

Screenshots/Preparation.png

Now you have your Huawei HMS Project and App information.

Create an app

Create an app by referring to Creating a Project and Creating an App in the Project. Set the following parameters as described:

  • Platform: Select Android
  • Device: Select Mobile phone
  • App category: Select App or Game

Screenshots/Step2.png Screenshots/Preparation.png

The integrating process is as follows Screenshots/ads_process.png

Refer to Sign the agreement to sign the Huawei Ads Publisher Service Agreement.

If your app has been or will be released on AppGallery, follow to Adding an App Released on Huawei AppGallery. If your app is released on Google Play, add it by referring to Adding an App Released on Google Play. If your app has been released on both AppGallery and Google Play and the package names are the same, select AppGallery as the app source. Notice: If your app package changes on other app stores, update it in a timely manner on HUAWEI Ads Publisher Console. Otherwise, traffic monetization will be affected.

Refer to Adding/Enabling an Ad Unit to obtain your ad unit ID

Prepare for development

According to HMS integration process introduction, we still need to add some configurations to the gradle files for development preparations.

Screenshots/Step3.png

1. Install the Plugin

Copy and enable the Unreal Engine Plugin.

If a <unreal_project_directory>/Plugins folder does not exist, create it.

From the Huawei Ads Unreal plugin, copy the HuaweiAds folder and its contents to <unreal_project_directory>/Plugins. Screenshots/unreal-step1

From your Unreal Editor, select Edit -> Plugins menu then enable the Huawei Ads Plugin. Screenshots/unreal-step2

2. Package name

Set the package name in Edit -> Project Settings -> Android -> APK Packaging -> Android Package Name

The package name is com.${Company Name}.${Product Name}.

You can also complete the rest of the settings here, such as version number, icons, resolution, etc.

Screenshots/unreal-step3.png

3. Set up plugin

  • Sign in to AppGallery Connect and click My projects.
  • Find your app project and click the app that needs to integrate the HMS Core SDK.
  • Go to Project settings > General information. In the App information area, download the agconnect-services.json file. Screenshots/agc_json.png
  • You can put the json file under <unreal_project_directory>/Configs/AGC as default (create the Configs/AGC directory if not existed) or in your own favorite path Screenshots/unreal-step4.png

Developing with the SDK

Supported Ad formats

Ad Format
Ad Type Description
Banner Ads Image A banner ad is presented as a bar or block at the top, middle, or bottom of the screen within an app with high visibility for users who use the app regularly or for a long time.
Rewarded Ads Video A rewarded ad is displayed when a user achieves a level, gets respawned, obtains items, bonus points, or opportunities to continue, or upgrades skills in a game.
Interstitial Ads Image or video An interstitial ad is displayed when a user starts, pauses, loads, or exits a game or streaming media, achieves a game level, or is redirected in a game or streaming media.

Another ad formats will be supported in the future.

Developing

Using Blueprint

The below functions are supported with Blueprint

  • loadBannerAd
  • showBannerAd
  • hideBannerAd
  • destroyBannerAd
  • loadInterstitialAd
  • showInterstitialAd
  • loadRewardAd You can refer to the Blueprint sample. Screenshots/blueprint.png

Using C++ APIs

Access the Huawei Ads APIs by including the header file Ads.h in the related classes of your project.

#include "Ads.h"
  • Loading the banner ad
huawei::Ads::loadBannerAd("testw6vs28auh3", BannerPosition::POSITION_BOTTOM, BannerSize::BANNER_SIZE_320_100);

You can refer to the following banner position and banner size enum defintions

enum BannerPosition
{
    POSITION_CUSTOM = -1,
    POSITION_TOP = 0,
    POSITION_BOTTOM = 1,
    POSITION_TOP_LEFT = 2,
    POSITION_TOP_RIGHT = 3,
    POSITION_BOTTOM_LEFT = 4,
    POSITION_BOTTOM_RIGHT = 5,
    POSITION_CENTER = 6
};

enum BannerSize
{
    USER_DEFINED,
    BANNER_SIZE_320_50,
    BANNER_SIZE_320_100,
    BANNER_SIZE_468_60,
    BANNER_SIZE_DYNAMIC,
    BANNER_SIZE_728_90,
    BANNER_SIZE_300_250,
    BANNER_SIZE_SMART,
    BANNER_SIZE_160_600,
    BANNER_SIZE_360_57,
    BANNER_SIZE_360_144
};
  • Show the banner ad

Banner ad will be shown automatically after finishing loading but you can use this function to show it on demand

Sample code

huawei::Ads:showBannerAd();
  • Hide the banner ad

Sample code

huawei::Ads::hideBannerAd();
  • Destroy the banner ad

Banner ad will be destroyed automatically on the OnDestroy lifecycle event but you can use this function to destroy it on demand

Sample code

huawei::Ads::destroyBannerAd();
  • Load an interstitial ad

Sample code

huawei::Ads::loadInterstitialAd("testb4znbuh3n2");
  • Show an intersitial ad

Intersitial ad will be shown automatically after finishing loading but you can use this function to show it on demand

Sample code

huawei::Ads::showInterstitialAd();
  • Load an reward ad

Sample code

huawei::Ads::loadRewardAd("testx9dtjwj8hp");
  • Show an reward ad

Reward ad will be shown automatically after finishing loading but you can use this function to show it on demand

Sample code

huawei::Ads::showRewardAd();
  • Listen to callback events Implement a listener class to receive information in all the Ads callback events

Sample code Header file

class YourAdsListener : public huawei::AdsListener 
{
public:
    YourAdsListener();
    
    virtual void onBannerAdClosed() override;
    virtual void onBannerAdFailed(int errorCode) override;
    virtual void onBannerAdLeftApp() override;
    virtual void onBannerAdOpened() override;
    virtual void onBannerAdLoaded() override;
    virtual void onBannerAdClicked() override;
    virtual void onBannerAdImpression() override;
    virtual void onInterstitialAdClosed() override;
    virtual void onInterstitialAdFailed(int errorCode) override;
    virtual void onInterstitialAdLeftApp() override;
    virtual void onInterstitialAdOpened() override;
    virtual void onInterstitialAdLoaded() override;
    virtual void onInterstitialAdClicked() override;
    virtual void onInterstitialAdImpression() override;
    virtual void onRewardAdFailedToLoad(int errorCode) override;
    virtual void onRewardedLoaded() override;
    virtual void onRewardAdClosed() override;
    virtual void onRewardAdFailedToShow(int errorCode) override;
    virtual void onRewardAdOpened() override;
    virtual void onRewarded(const FString type, int amount) override;
}  

Then set it with the setListener API

Sample code

huawei::Ads::setListener(new YourAdsListener());

Test & Release

Please refer to Huawei Testing and Releasing your app for testing and releasing.

Screenshots/TestAndRelease.png

Screenshots/TestingReleasing.png

About

Unreal Plugin for Huawei Ads kit

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C++ 97.9%
  • C# 2.1%