Skip to content

EvilMindDevs/run-mori-run-hms-push

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

6 Commits
 
 
 
 
 
 
 
 

Repository files navigation

Unity Mobile Reference Game with Push Service

image

The HMS Unity plugin helps you integrate all the power of Huawei Mobile Services in your Unity game:

  • Push notifications

Game

image

This project is a basic hypercasual game for Unity mobile platform with Huawei Mobile Services Plugin Push Service integration.

Purpose: Try to not touch obstacle

Push Service Features:

You can send a notification message is directly sent by Push Kit and displayed in the notification panel on the user device, not requiring your app to be running in the background

You can send data messages are processed by your app on user devices.

Requirements

Android SDK min 21 Net 4.x

Important

This plugin supports:

  • Unity version 2019, 2020 - Developed in master Branch
  • Unity version 2018 - Developed in 2.0-2018 Branch

Make sure to download the corresponding unity package for the Unity version you are using from the release section

Troubleshooting 1

Please check our wiki page

Status

This is an ongoing project, currently WIP. Feel free to contact us if you'd like to collaborate and use Github issues for any problems you might encounter. We'd try to answer in no more than a working day.

Connect your game Huawei Mobile Services in 5 easy steps

  1. Register your app at Huawei Developer
  2. Import the Plugin to your Unity project
  3. Connect your game with the HMS Kit Managers

1 - Register your app at Huawei Developer

1.1- Register at Huawei Developer

1.2 - Create an app in AppGallery Connect.

During this step, you will create an app in AppGallery Connect (AGC) of HUAWEI Developer. When creating the app, you will need to enter the app name, app category, default language, and signing certificate fingerprint. After the app has been created, you will be able to obtain the basic configurations for the app, for example, the app ID and the CPID.

  1. Sign in to Huawei Developer and click Console.
  2. Click the HUAWEI AppGallery card and access AppGallery Connect.
  3. On the AppGallery Connect page, click My apps.
  4. On the displayed My apps page, click New.
  5. Enter the App name, select App category (Game), and select Default language as needed.
  6. Upon successful app creation, the App information page will automatically display. There you can find the App ID and CPID that are assigned by the system to your app.

1.3 Add Package Name

Set the package name of the created application on the AGC.

  1. Open the previously created application in AGC application management and select the Develop TAB to pop up an entry to manually enter the package name and select manually enter the package name.
  2. Fill in the application package name in the input box and click save.

Your package name should end in .huawei in order to release in App Gallery

Generate a keystore.

Create a keystore using Unity or Android Tools. make sure your Unity project uses this keystore under the Build Settings>PlayerSettings>Publishing settings

Generate a signing certificate fingerprint.

During this step, you will need to export the SHA-256 fingerprint by using keytool provided by the JDK and signature file.

  1. Open the command window or terminal and access the bin directory where the JDK is installed.

  2. Run the keytool command in the bin directory to view the signature file and run the command.

    keytool -list -v -keystore D:\Android\WorkSpcae\HmsDemo\app\HmsDemo.jks

  3. Enter the password of the signature file keystore in the information area. The password is the password used to generate the signature file.

  4. Obtain the SHA-256 fingerprint from the result. Save for next step.

Add fingerprint certificate to AppGallery Connect

During this step, you will configure the generated SHA-256 fingerprint in AppGallery Connect.

  1. In AppGallery Connect, click the app that you have created and go to Develop> Overview
  2. Go to the App information section and enter the SHA-256 fingerprint that you generated earlier.
  3. Click √ to save the fingerprint.

2 - Import the plugin to your Unity Project

To import the plugin:

  1. Download the .unitypackage
  2. Open your game in Unity
  3. Choose Assets> Import Package> Custom Import Package
  4. In the file explorer select the downloaded HMS Unity plugin. The Import Unity Package dialog box will appear, with all the items in the package pre-checked, ready to install. image
  5. Select Import and Unity will deploy the Unity plugin into your Assets Folder

3 - Update your agconnect-services.json file.

In order for the plugin to work, some kits are in need of agconnect-json file. Please download your latest config file from AGC and import into Assets/StreamingAssets folder. image


4 - Connect your game with any HMS Kit

In order for the plugin to work, you need to select the needed kits Huawei > Kit Settings.

In this Push Service reference game , I selected the Push Kit.

2

Push Service is not dependent any other sevices.
It will automaticaly create the GameObject for you and it has DontDestroyOnLoad implemented so you don't need to worry about reference being lost.

Now you need your game to call the Push Manager from your game. See below for further instructions.

Then you can call certain functions such as

  HMSPushKitManager.Instance.OnTokenSuccess = OnNewToken;
  HMSPushKitManager.Instance.OnTokenFailure = OnTokenError;
  HMSPushKitManager.Instance.OnTokenBundleSuccess = OnNewToken;
  HMSPushKitManager.Instance.OnTokenBundleFailure = OnTokenError;
  HMSPushKitManager.Instance.OnMessageSentSuccess = OnMessageSent;
  HMSPushKitManager.Instance.OnSendFailure = OnSendError;
  HMSPushKitManager.Instance.OnMessageDeliveredSuccess = OnMessageDelivered;
  HMSPushKitManager.Instance.OnMessageReceivedSuccess = OnMessageReceived;
  HMSPushKitManager.Instance.OnNotificationMessage = OnNotificationMessage;
  HMSPushKitManager.Instance.NotificationMessageOnStart = NotificationMessageOnStart;

public void OnMessageReceived(RemoteMessage remoteMessage)
{
    var id = remoteMessage.MessageId;
    var from = remoteMessage.From;
    var to = remoteMessage.To;
    var data = remoteMessage.Data;
    remoteMessageText.text = $"ID: {id}\nFrom: {from}\nTo: {to}\nData: {data}";
}
public void OnNewToken(string token, Bundle bundle)
{
    Debug.Log($"[HMS] Push token from OnNewToken is {pushToken}");
    if (pushToken == null)
    {
        pushToken = token;
    }
}
 

Troubleshooting 2

1.If you received package name error , please check your package name on File->Build Settings -> Player Settings -> Other Settings -> Identification

image

2.If you received min sdk error ,

image

please set your API level as implied in the Requirements section

image

Push

Official Documentation on Push Kit: Documentation

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published