活动识别API服务开发
活动识别API服务开发
要使用华为活动识别服务API,需要确保设备已经下载并安装了HMS Core(APK),并将Location Kit的SDK集成到项目中。
指定应用权限
- 在Android Q以下版本使用活动识别需要在“AndroidManifest.xml”文件中配置以下权限:
- <uses-permission android:name="com.huawei.hms.permission.ACTIVITY_RECOGNITION"/>
- 在Android Q及以上版本中,需要在“AndroidManifest.xml”文件中申请以下权限:
. <uses-permission android:name="android.permission.ACTIVITY_RECOGNITION" />
说明
以上活动识别相关权限属于危险权限,使用时需要动态申请。
注册静态广播
示例代码中活动识别服务的活动状态更新信息需要广播接收,因此需要在“AndroidManifest.xml”文件中注册广播接收器。
- <!--注册活动识别服务广播接收器-->
- <receiver
- android:name=".location.fusedlocation.LocationBroadcastReceiver"
- android:exported="true">
- <intent-filter>
- <action android:name="com.huawei.hmssample.location.LocationBroadcastReceiver.ACTION_PROCESS_LOCATION" />
- </intent-filter>
- </receiver>
创建活动识别服务客户端
在Activity的OnCreate()方法中创建一个ActivityIdentificationService实例,通过该实例调用活动识别相关接口:
- private PendingIntent pendingIntent;
- private ActivityIdentificationService activityIdentificationService;
- protected void onCreate(Bundle savedInstanceState) {
- // 通过ActivityIdentification.getService()创建activityIdentificationService实例
- activityIdentificationService = ActivityIdentification.getService(this);
- // 获取PendingIntent对象
- pendingIntent = getPendingIntent();
- }
活动识别更新
使用活动识别服务,首先需要注册活动识别更新,可以检测用户当前是步行、骑自行车、静止等状态。
- 新建PendingIntent。
- // 获取自定义静态广播类LocationBroadcastReceiver关联的PendingIntent
- private PendingIntent getPendingIntent() {
- Intent intent = new Intent(this, LocationBroadcastReceiver.class);
- intent.setAction(LocationBroadcastReceiver.ACTION_PROCESS_LOCATION);
- return PendingIntent.getBroadcast(this, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT);
- }
- 监听活动识别更新请求。
通过调用createActivityIdentificationUpdates(long detectionIntervalMillis, PendingIntent callbackIntent)方法,第一个参数为活动检测更新间隔(单位为毫秒),第二个参数pendingIntent。
- // 创建活动识别请求
- activityIdentificationService.createActivityIdentificationUpdates(5000, pendingIntent)
- // 请求成功监听回调
- .addOnSuccessListener(new OnSuccessListener<Void>() {
- @Override
- public void onSuccess(Void aVoid) {
- Log.i(TAG, "createActivityIdentificationUpdates onSuccess");
- }
- })
- 10. // 请求失败监听回调
- 11. .addOnFailureListener(new OnFailureListener() {
- 12. @Override
- 13. public void onFailure(Exception e) {
- 14. Log.e(TAG, "createActivityIdentificationUpdates onFailure:" + e.getMessage());
- 15. }
- 16. });
- 移除活动识别更新。
在使用完活动识别后需要进行移除操作。调用deleteActivityIdentificationUpdates(PendingIntent pendingIntent)移除活动识别定时监听,参数PendingIntent必须与createActivityIdentificationUpdates(long detectionIntervalMillis, PendingIntent callbackIntent)参数里的PendingIntent是同一个。
- // 移除活动识别更新
- activityIdentificationService.deleteActivityIdentificationUpdates(pendingIntent)
- // 移除回调成功监听回调
- .addOnSuccessListener(new OnSuccessListener<Void>() {
- @Override
- public void onSuccess(Void aVoid) {
- Log.i(TAG, "deleteActivityIdentificationUpdates onSuccess");
- }
- })
- 10. // 移除回调失败监听回调
- 11. .addOnFailureListener(new OnFailureListener() {
- 12. @Override
- 13. public void onFailure(Exception e) {
- 14. Log.e(TAG, "deleteActivityIdentificationUpdates onFailure:" + e.getMessage());
- 15. }
- 16. });
- 活动识别结果获取。
通过广播接收到的intent中获取活动识别结果。
- // 活动识别广播接收者
- public class LocationBroadcastReceiver extends BroadcastReceiver {
- // 活动识别服务广播action
- public static final String ACTION_PROCESS_LOCATION = "com.huawei.hms.location.ACTION_PROCESS_LOCATION";
- @Override
- public void onReceive(Context context, Intent intent) {
- if (intent != null) {
- final String action = intent.getAction();
- 10. if (ACTION_PROCESS_LOCATION.equals(action)) {
- 11. // 从活动识别服务发送的intent的extras中获取ActivityIdentificationResponse
- 12. ActivityIdentificationResponse activityIdentificationResponse = ActivityIdentificationResponse.getDataFromIntent(intent);
- 13. List<ActivityIdentificationData> list = activityIdentificationResponse.getActivityIdentificationDatas();
- 14. }
- 15. }
- 16. }
17. }
活动过渡更新
接口提供检测活动过渡条件(进入、退出)的功能,例如需要检测用户从走路变为骑自行车的状态时,应用通过调用createActivityConversionUpdates(ActivityConversionRequest request, PendingIntent pendingIntent)方法获取活动过渡的状态变化。
- 设置监听活动过渡请求参数。
- // 创建一个静止状态进入活动转换信息对象
- ActivityConversionInfo activityConversionInfoStillEnter = new ActivityConversionInfo(ActivityIdentificationData.STILL, ActivityConversionInfo.ENTER_ACTIVITY_CONVERSION);
- // 创建一个静止状态退出活动转换信息对象
- ActivityConversionInfo activityConversionInfoStillExit = new ActivityConversionInfo(ActivityIdentificationData.STILL, ActivityConversionInfo.EXIT_ACTIVITY_CONVERSION);
- List<ActivityConversionInfo> activityConversionInfos = new ArrayList<>();
- activityConversionInfos.add(activityConversionInfoStillEnter);
- activityConversionInfos.add(activityConversionInfoStillExit);
- // 创建一个活动转换请求体实例
- ActivityConversionRequest request = new ActivityConversionRequest();
10. request.setActivityConversions(activityConversionInfos);
- 监听活动过渡更新。
- // 监听活动识别状态转换
- Task<Void> task = activityIdentificationService.createActivityConversionUpdates(request, pendingIntent);
- // 任务成功监听回调
- task.addOnSuccessListener(new OnSuccessListener<Void>() {
- @Override
- public void onSuccess(Void aVoid) {
- Log.i(TAG, "createActivityConversionUpdates onSuccess");
- }
- })
- 10. // 任务失败监听回调
- 11. .addOnFailureListener(new OnFailureListener() {
- 12. @Override
- 13. public void onFailure(Exception e) {
- 14. Log.e(TAG, "createActivityConversionUpdates onFailure:" + e.getMessage());
- 15. }
- 16. });
- (可选)移除活动过渡更新。
不需要监听活动过渡条件时,需要调用deleteActivityConversionUpdates(PendingIntent pendingIntent)进行移除操作。
- // 通过指定pendingIntent移除活动转换更新
- activityIdentificationService.deleteActivityConversionUpdates(pendingIntent)
- // 移除更新成功监听回调
- .addOnSuccessListener(new OnSuccessListener<Void>() {
- @Override
- public void onSuccess(Void aVoid) {
- Log.i(TAG, "deleteActivityConversionUpdates onSuccess");
- }
- })
- 10. // 移除更新失败监听回调
- 11. .addOnFailureListener(new OnFailureListener() {
- 12. @Override
- 13. public void onFailure(Exception e) {
- 14. Log.e(TAG, "deleteActivityConversionUpdates onFailure:" + e.getMessage());
- 15. }
- 16. });
- 返回结果获取。
活动过渡的结果:
- public class LocationBroadcastReceiver extends BroadcastReceiver {
- public static final String ACTION_PROCESS_LOCATION = "com.huawei.hms.location.ACTION_PROCESS_LOCATION";
- @Override
- public void onReceive(Context context, Intent intent) {
- if (intent != null) {
- final String action = intent.getAction();
- if (ACTION_PROCESS_LOCATION.equals(action)) {
- // 从intent中获取ActivityConversionResponse
- 10. ActivityConversionResponse activityConversionResponse = ActivityConversionResponse.getDataFromIntent(intent);
- 11. List<ActivityConversionData> list = activityConversionResponse.getActivityConversionDatas();
- 12. }
- 13. }
- 14. }
15. }
说明
海外版本手机活动识别不支持骑行和乘车。