You can use the user actions APIs below to measure your user’s engagement with your app.
Actions are events that occur in your app. Use this API to track and measure an action, where each action has one or more corresponding metrics that increment each time the event occurs. For example, you might call this API for each new subscription each time an article is viewed, or each time a level is completed.
This section shows you how to start tracking app screens and user actions. To view and report on this data in those respective solutions, set up Analytics or other Experience Cloud solution extensions.
{% hint style="warning" %} You must call this API when an event that you want to track occurs. In addition to the action name, you can send additional context data with each track action call. {% endhint %}
{% tabs %} {% tab title="Android" %}
public static void trackAction(final String action, final Map<String, String> contextData)Map<String, String> additionalContextData = new HashMap<String, String>();
additionalContextData.put("customKey", "value");
MobileCore.trackAction("loginClicked", additionalContextData);{% endtab %}
{% tab title="iOS" %}
+ (void) trackAction: (nullable NSString*) action data: (nullable NSDictionary*) data;
[ACPCore trackAction:@"action name" data:@{@"key":@"value"}];
+ (void) trackAction: (nullable NSString*) action data: (nullable NSDictionary*) data;
ACPCore.trackAction("action name", data: ["key": "value"]){% endtab %}
{% tab title="React Native" %}
trackAction(action?: String, contextData?: { string: string });ACPCore.trackAction("action", {"mytest": "action"});{% endtab %}
{% tab title="Flutter" %}
Future<void> trackAction(String action, {Map<String, String> data});FlutterACPCore.trackAction("mytest", data: {"mytest": "action"});J{% endtab %}
{% tab title="Cordova" %}
ACPCore.trackAction("cordovaAction", {"cordovaKey":"cordovaValue"}, successCallback, errorCallback);{% endtab %}
{% tab title="Unity" %}
var contextData = new Dictionary<string, string>();
contextData.Add("key", "value");
ACPCore.TrackAction("action name", contextData);{% endtab %}
{% tab title="Xamarin" %}
iOS
var data = new NSMutableDictionary<NSString, NSString>
{
["key"] = new NSString("value")
};
ACPCore.TrackAction("action", data);Android
var data = new Dictionary<string, string>();
data.Add("key", "value");
ACPCore.TrackAction("action", data);{% endtab %} {% endtabs %}
States represent screens or views in your app. Each time a new state is displayed in your application, for example, when a user navigates from the home page to the news feed, this method might be called. This method also sends an Analytics state tracking hit with optional context data.
{% tabs %} {% tab title="Android" %}
In Android, trackState is typically called each time a new activity is loaded.
public static void trackState(final String state, final Map<String, String> contextData)Map<String, String> additionalContextData = new HashMap<String, String>();
additionalContextData.put("customKey", "value");
MobileCore.trackState("homePage", additionalContextData);{% endtab %}
{% tab title="iOS" %}
+ (void) trackState: (nullable NSString*) state data: (nullable NSDictionary*) data;
[ACPCore trackState:@"state name" data:@{@"key":@"value"}];
+ (void) trackState: (nullable NSString*) state data: (nullable NSDictionary*) data;
ACPCore.trackState("state name", data: ["key": "value"]){% endtab %}
{% tab title="React Native" %}
trackState(state?: String, contextData?: { string: string });ACPCore.trackState("state", {"mytest": "state"});{% endtab %}
{% tab title="Flutter" %}
Future<void> trackState(String state, {Map<String, String> data});FlutterACPCore.trackState("state", data: {"mytest": "state"});{% endtab %}
{% tab title="Cordova" %}
ACPCore.trackState("cordovaState", {"cordovaKey":"cordovaValue"}, successCallback, errorCallback);{% endtab %}
{% tab title="Unity" %}
var dict = new Dictionary<string, string>();
dict.Add("key", "state value");
ACPCore.TrackState("state", dict);{% endtab %}
{% tab title="Xamarin" %}
iOS
var data = new NSMutableDictionary<NSString, NSString>
{
["key"] = new NSString("value")
};
ACPCore.TrackState("state", data);Android
var data = new Dictionary<string, string>();
data.Add("key", "value");
ACPCore.TrackState("state", data);{% endtab %} {% endtabs %}
For more information, see Mobile Core API Reference.
- Visit the SDK community forum to ask questions
- Contact Adobe Experience Cloud customer care for immediate assistance