Overview

Analytics Kit predefines rich analysis models to help you easily understand user behavior and gain in-depth insights into users, products, and content. As such, you can carry out data-driven operations and make informed decisions about app marketing and product optimization.
Analytics Kit implements the following functions using data collected from apps:

What You Will Create

In this codelab, you will create a demo app based on the provided demo project. After creating a demo app, you will be able to:

What You Will Learn

In this codelab, you will learn how to:

Hardware Requirements

Software Requirements

Required Knowledge

To integrate Analytics Kit, you must complete the following preparations:

  1. Sign in to AppGallery Connect and click My projects.
  2. Find your project and select the app that needs to integrate the Analytics SDK.
  3. Select any menu under HUAWEI Analytics and click Enable Analytics service. (You must have the app management permission to perform this operation.)
  4. On the Project access settings page displayed, set the data processing location and complete other settings. Then click Finish.
  5. Download the configuration file.
  6. In Android Studio, switch to the Project view and copy the agconnect-services.json file to your app-level directory.

Adding SDK Dependencies

  1. Add the Maven repository address and AppGallery Connect dependency to the build.gradle file of your project.

    a) Open the project-level build.gradle file.

    b) Configure the Maven repository address for the HMS Core SDK.
    For details, please refer to Configuring the Maven Repository Address for the HMS Core SDK.

    c) Add the AppGallery Connect dependency to dependencies.

    dependencies { classpath 'com.huawei.agconnect:agcp:1.6.0.300' }
  2. Add the Analytics Kit dependency to the app-level build.gradle file.

    a) Open the app-level build.gradle file.

    b) Add the build dependency to dependencies.

    dependencies { implementation 'com.huawei.hms:hianalytics:6.7.0.300' }
  3. c)Add the AppGallery Connect plugin configuration.
    Method 1: add the following information under apply plugin: 'com.android.application' in the file header:

    apply plugin: 'com.huawei.agconnect'

    Method 2: add the plugin configuration to the plugins block:

    plugins { id 'com.android.application' // Add the following configuration: id 'com.huawei.agconnect' }
  4. Click Sync Now or Sync Project with Gradle Files to build a project.

Configuring Obfuscation Scripts

1. Open the app-level obfuscation configuration file proguard-rules.pro of your project and add configurations to exclude the HMS Core SDK from obfuscation.

-ignorewarnings -keepattributes *Annotation* -keepattributes Exceptions -keepattributes InnerClasses -keepattributes Signature -keepattributes SourceFile,LineNumberTable -keep class com.huawei.hianalytics.**{*;} -keep class com.huawei.updatesdk.**{*;} -keep class com.huawei.hms.**{*;}

2. If you are using AndResGuard, add its trustlist to the obfuscation configuration file.

"R.string.hms*", "R.string.connect_server_fail_prompt_toast", "R.string.getting_message_fail_prompt_toast", "R.string.no_available_network_prompt_toast", "R.string.third_app_*", "R.string.upsdk_*", "R.layout.hms*", "R.layout.upsdk_*", "R.drawable.upsdk*", "R.color.upsdk*", "R.dimen.upsdk*", "R.style.upsdk*", "R.string.agc*"

In this section, you will try to build a demo with the question answering function to learn how to use the main APIs of Analytics Kit. We have prepared the code for you, meaning you only need to follow the instructions in each step below to learn how to use Analytics Kit to report the events you are interested in, such as answering questions, calculating scores, and setting user attributes.

Download

Extracting Sample Code to the src Directory

Copying Code Files

Copy all Java files from the code directory to your project.

Copying Resource Files

Copy all resource files from the res directory to your project.

Modifying AndroidManifest.xml

  1. Configure the app installation source, for example, AppGallery, in meta-data in the application element.
  2. <application ...... <meta-data android:name="install_channel" android:value="AppGallery"> </meta-data> ...... </application>
  3. Declare SettingActivity in the application element.
  4. <application <activity> android:name=".SettingActivity"> </activity> </application>

    Your app is so far loaded with the required functions. Next, you will use Analytics Kit to report the events that interest you.

Modifying the MainActivity Class

  1. Add the following code to import classes from Analytics Kit:
  2. // TODO: Import classes from Analytics Kit. import com.huawei.hms.analytics.HiAnalytics; import com.huawei.hms.analytics.HiAnalyticsInstance; import com.huawei.hms.analytics.HiAnalyticsTools; import static com.huawei.hms.analytics.type.HAEventType.*; import static com.huawei.hms.analytics.type.HAParamType.*;
  3. Add the following code to define a variable for the Analytics Kit instance:
  4. private int score = 0; // TODO: Define a variable for the Analytics Kit instance. HiAnalyticsInstance instance;
  5. Add the following code in the onCreate method to initialize Analytics Kit:
  6. @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); // TODO: Initialize Analytics Kit. // Enable Analytics Kit logging. HiAnalyticsTools.enableLog(); // Generate an Analytics Kit instance. instance = HiAnalytics.getInstance(this); txtQuestion = (TextView)findViewById(R.id.question_text_view); txtQuestion.setText(questions[curQuestionIdx]); }
  7. Add the following code to implement the reportAnswerEvt method:
  8. private void reportAnswerEvt(String answer) { // TODO: Report a custom event. // Event name: Answer // Event parameters: // -- question: String // -- answer: String // -- answerTime: String // Initialize parameters. Bundle bundle = new Bundle(); bundle.putString("question", txtQuestion.getText().toString().trim()); bundle.putString("answer",answer); SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss", Locale.ENGLISH); bundle.putString("answerTime",sdf.format(new Date())); // Report a custom event. instance.onEvent("Answer", bundle); }
  9. Add the following code to implement the postScore method:
  10. private void postScore() { // TODO: Report a score through the SUBMITSCORE event. // Initialize parameters. Bundle bundle = new Bundle(); bundle.putLong(SCORE, score); // Report a predefined event. instance.onEvent(SUBMITSCORE, bundle); }

Modifying the SettingActivity Class

  1. Add the following code to import classes from Analytics Kit:
  2. // TODO: Import classes from Analytics Kit. import com.huawei.hms.analytics.HiAnalytics; import com.huawei.hms.analytics.HiAnalyticsInstance;
  3. Add the following code to define a variable for the Analytics Kit instance:
  4. // TODO: Define a variable for the Analytics Kit instance. HiAnalyticsInstance instance;
  5. Add the following code to initialize Analytics Kit:
  6. // TODO: Generate an Analytics Kit instance. instance = HiAnalytics.getInstance(this);
  7. Add the following code to save user attributes:>
  8. btnSave.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { editFavorSport = (EditText)findViewById(R.id.edit_favorite_sport); // TODO: Set users' favorite sport using the setUserProfile API. instance.setUserProfile("favor_sport",strFavorSport); } });

    For details about APIs, please refer to the Analytics Kit API Reference.

Start the app in the emulator and trigger event reporting as instructed.

  1. Sign in to AppGallery Connect and click My projects.
  2. Find your project, and click the app to view its data.
  3. Go to HUAWEI Analytics > Overview > Real-time overview.
  4. Check the data. For details, please refer to the Analytics Kit operation guide.
  1. Run the following command to enable the debug mode on an Android device:
  2. adb shell setprop debug.huawei.hms.analytics.app <package_name>

    After the debug mode is enabled, all triggered events are reported to the App debugging page in real time.

  3. View the reported debugging data.
  4. To disable the debug mode, run the following command:

    adb shell setprop debug.huawei.hms.analytics.app .none.

FAQs

How should I perform initialization?

How does Analytics Kit identify users?

When will the AAID be reset? How does Analytics Kit collect user statistics after AAID reset?

What permissions are required for using Analytics Kit?

Why can't I view the analysis result of the data reported during the test?

  1. When app debugging is disabled, you can only view some analysis results on the Real-time overview page. Analysis results on other pages such as Event analysis and Launch analysis are available only after the corresponding data is processed on the next day.
  2. When app debugging is enabled, the reported test data will not be analyzed and can only be viewed on the App debugging page.

What should I do if a gradle-wrapper.properties file error is reported?

Well done. You have successfully completed this codelab and learned how to:

For more information, please click the following link:

Related documents
To download the sample code, please click the button below:

Download

Code copied