Intégration de messages in-app
Cet article de référence couvre les directives de configuration de l’envoi de messages in-app pour la plateforme Unity.
Configuration du comportement par défaut des messages in-app
Sur Android, les messages in-app de Braze sont nativement affichés automatiquement. Pour désactiver cette fonctionnalité, désélectionnez l’option Afficher automatiquement les messages in-app dans l’éditeur de configuration de Braze.
Vous pouvez également définir com_braze_inapp_show_inapp_messages_automatically
sur false
dans votre projet Unity braze.xml
.
L’opération d’affichage du message in-app initial peut être configurée dans la configuration de Braze, via « Opération d’affichage du gestionnaire initial de message in-app ».
Sur iOS, les messages in-app de Braze sont nativement affichés automatiquement. Pour désactiver cette fonctionnalité, définissez les auditeurs d’objet de jeu dans l’éditeur de configuration Braze et assurez-vous que Braze affiche les messages in-app ne soit pas sélectionné.
L’opération d’affichage du message in-app initial peut être configurée dans la configuration de Braze, via « Opération d’affichage du gestionnaire initial de message in-app ».
Configuration du comportement d’affichage des messages in-app
Vous pouvez éventuellement modifier le comportement d’affichage des messages in-app au moment de l’exécution via les éléments suivants :
1
2
3
4
5
6
7
8
// Sets in-app messages to display immediately when triggered.
Appboy.AppboyBinding.SetInAppMessageDisplayAction(BrazeUnityInAppMessageDisplayActionType.IAM_DISPLAY_NOW);
// Sets in-app messages to display at a later time and be saved in a stack.
Appboy.AppboyBinding.SetInAppMessageDisplayAction(BrazeUnityInAppMessageDisplayActionType.IAM_DISPLAY_LATER);
// Sets in-app messages to be discarded after being triggered.
Appboy.AppboyBinding.SetInAppMessageDisplayAction(BrazeUnityInAppMessageDisplayActionType.IAM_DISCARD);
Affichage des messages in-app à la demande
Vous pouvez afficher le prochain message in-app disponible dans la pile à l’aide de la méthode DisplayNextInAppMessage()
. Les messages sont ajoutés à la pile des messages enregistrés siDISPLAY_LATER
ou BrazeUnityInAppMessageDisplayActionType.IAM_DISPLAY_LATER
est choisi dans l’action d’affichage du message in-app.
1
Appboy.AppboyBinding.DisplayNextInAppMessage();
Réception des données de message in-app dans Unity
Vous pouvez lister des objets de jeu Unity pour être avertis des messages in-app entrants. Nous recommandons de définir des auditeurs d’objets de jeu à partir de l’éditeur de configuration Braze. Dans l’éditeur de configuration, les auditeurs doivent être définis séparément pour Android et iOS.
Si vous devez configurer votre auditeur d’objet de jeu lors de l’exécution, utilisez AppboyBinding.ConfigureListener()
et spécifiez BrazeUnityMessageType.IN_APP_MESSAGE
.
Analyse des messages in-app
Les messages string
entrants reçus dans votre rappel d’objet de jeu de messages in-app peuvent être analysés dans nos objets de modèle pré-fournis pour plus de commodité.
Utiliser InAppMessageFactory.BuildInAppMessage()
pour analyser votre message in-app. L’objet résultant sera soit une instance de IInAppMessage.cs
ou IInAppMessageImmersive.cs
en fonction de son type.
Exemple de rappel de message in-app
1
2
3
4
5
6
7
8
9
10
// Automatically logs a button click, if present.
void InAppMessageReceivedCallback(string message) {
IInAppMessage inApp = InAppMessageFactory.BuildInAppMessage(message);
if (inApp is IInAppMessageImmersive) {
IInAppMessageImmersive inAppImmersive = inApp as IInAppMessageImmersive;
if (inAppImmersive.Buttons != null && inAppImmersive.Buttons.Count > 0) {
inAppImmersive.LogButtonClicked(inAppImmersive.Buttons[0].ButtonID);
}
}
}
Support GIF
You can add animated GIFs to your in-app messages using the native Braze Android SDK. By default, the Android SDK uses HTML in-app messages to display GIFs.
For all other in-app message types, you’ll need to use a custom image library. To learn more, see Android In-App Messaging: GIFs.
You can add animated GIFs to your in-app messages using the native Braze Swift SDK. By default, all Braze in-app messages support GIFs. For a full walkthrough, see Tutorial: GIF Support for Swift In-App Messages.
Analyse
Les clics et les impressions doivent être enregistrés manuellement pour les messages in-app non affichés directement par Braze.
Utilisez LogClicked()
et LogImpression()
sur IInAppMessage
pour enregistrer les clics et les impressions sur votre message.
Utilisez LogButtonClicked(int buttonID)
sur IInAppMessageImmersive
pour enregistrer les clics sur les boutons. Notez que les boutons sont conseillés sous forme de listes d’instances deInAppMessageButton
dont chacune contient une instance ButtonID
.
Ecoutes d’actions personnalisées
Si vous avez besoin de plus de contrôle sur la façon dont un utilisateur interagit avec les messages in-app, utilisez un BrazeInAppMessageListener
et attribuez-le à Appboy.AppboyBinding.inAppMessageListener
. Concernant les délégués que vous ne souhaitez pas utiliser, vous pouvez simplement les laisser définis comme null
.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
BrazeInAppMessageListener listener = new BrazeInAppMessageListener() {
BeforeInAppMessageDisplayed = BeforeInAppMessageDisplayed,
OnInAppMessageButtonClicked = OnInAppMessageButtonClicked,
OnInAppMessageClicked = OnInAppMessageClicked,
OnInAppMessageHTMLClicked = OnInAppMessageHTMLClicked,
OnInAppMessageDismissed = OnInAppMessageDismissed,
};
Appboy.AppboyBinding.inAppMessageListener = listener;
public void BeforeInAppMessageDisplayed(IInAppMessage inAppMessage) {
// Executed before an in-app message is displayed.
}
public void OnInAppMessageButtonClicked(IInAppMessage inAppMessage, InAppMessageButton inAppMessageButton) {
// Executed whenever an in-app message button is clicked.
}
public void OnInAppMessageClicked(IInAppMessage inAppMessage) {
// Executed whenever an in-app message is clicked.
}
public void OnInAppMessageHTMLClicked(IInAppMessage inAppMessage, Uri uri) {
// Executed whenever an HTML in-app message is clicked.
}
public void OnInAppMessageDismissed(IInAppMessage inAppMessage) {
// Executed whenever an in-app message is dismissed without a click.
}