Android系统对应用长时间运行的要求日趋严格,轨迹追踪应用可能会被系统杀死,导致轨迹上传不完整。我们梳理了有助于Android APP保活方法,供开发者参考。同时,开发者应在严格遵守《百度地图开放平台产品和服务隐私政策》并保证应用合法合规的前提下使用百度鹰眼服务。
方法一:开发者自行向华为申请加入后台APP白名单,加入白名单后具体申请方法可详询华为客服。以下提供过往开发者的经验供参考,但最终解释权为华为所有:https://github.com/852172891/Android-/tree/master
方法二:Android 8.0系统为实现降低功耗,会对后台应用获取用户当前位置的频率进行限制,只允许后台应用每小时接收几次位置更新。为了适配这一系统特性,开发者可以参考鹰眼Demo,生成一个前台服务通知,使得应用退到后台的时候,仍有前台通知在,从而规避Android 8.0系统对后台定位的限制。
核心代码如下:
Notification.Builder builder = new Notification.Builder(this);Intent notificationIntent = new Intent(this, TracingActivity.class);Bitmap icon = BitmapFactory.decodeResource(this.getResources(),R.mipmap.icon_tracing);NotificationManager notificationManager = (NotificationManager)getSystemService(Context.NOTIFICATION_SERVICE);// PendingIntentbuilder.setContentIntent(PendingIntent.getActivity(this, 0,notificationIntent, 0)).setLargeIcon(icon) // ().setContentTitle("") //.setSmallIcon(R.mipmap.icon_tracing) //.setContentText("...") //.setWhen(System.currentTimeMillis());if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O && null !=notificationManager) {NotificationChannel notificationChannel =new NotificationChannel("trace", "trace_channel",NotificationManager.IMPORTANCE_HIGH);notificationManager.createNotificationChannel(notificationChannel);builder.setChannelId("trace"); // Android OchannelId}notification = builder.build(); // Notificationnotification.defaults = Notification.DEFAULT_SOUND; //LBSTraceClient mClient = new LBSTraceClient(mContext);Trace mTrace = new Trace(serviceId, entityName);mTrace.setNotification(notification);
通过上述方式开启前台服务后无需开发者手动释放,鹰眼SDK内部会随着停止鹰眼服务一并释放。开启前台服务在其他版本Android系统中使用也可最大程度的增加定位进程的存活率,提升后台定位效果。
注意:在Android 8.0之后使用前台服务,需要申请以下权限:
<uses-permission android:name="android.permission.FOREGROUND_SERVICE"/>
Android 10.0系统对定位限制更新严格,新增了后台定位权限,如果应用退到后台仍需定位,需要申请以下权限:
<uses-permission android:name="android.permission.ACCESS_BACKGROUND_LOCATION"/>
判断鹰眼servcie存活有两种方法:
通常使用轨迹追踪的应用都需要长时间(后台)运行,开发者APP可尝试使用以下方式降低APP被杀死的概率:
若手机开启了省电模式、各手机厂商定制的优化模式(如小米手机的神隐模式)、第三方安全应用的省电模式(如360手机卫士),则进程可能会被杀死。 处理策略为,用户在手机端关闭省电模式,或将APP加入这些模式的白名单。
当手机系统内存不足时,会回收进程,直至内存充足时系统会自动重启进程。针对这种情况,可在APP内新增一个独立的进程B,定时查询鹰眼serviceA是否是否出于开启状态。当监听到鹰眼进程A被杀死,则重新开启鹰眼服务。但如果进程B同时也被系统回收,则该方法失效。
出于功耗和性能问题,当前Android允许禁止APP后台运行,即所谓的黑白名单。被禁止的APP是无法在后台运行,如果集成鹰眼SDK的APP需要后台继续运行,则需要设置允许后台运行。设置项大多手机都在设置功能的隐私和安全中提供。
手机(设备)在 锁屏状态下,Android系统会先进入浅休眠,然后深度休眠。APP会被挂起,导致集成鹰眼SDK的APP无法运行。设置手机(设备)保持屏幕常亮,可以防止休眠,保证APP运行。
Android系统中电池功耗逻辑,会在设备处于充电状态时,不限制某些高功耗的功能,诸如网络链接,结合“保持屏幕常亮”,可以使集成鹰眼SDK的APP保活。
为了确保MediaPlayer的承载的服务在系统睡眠的时候继续正常执行下去。Android为我们提供了一种唤醒锁(wake locks)的机制。它能够在系统睡眠时,依旧保持锁定硬件的正常工作。基于这种思路,可以在集成鹰眼SDK的APP中,使用Service继承MediaPlayer,播放一段无声音频文件,达到保活效果。确保在MediaPlayer执行的时候,哪怕系统睡眠了CUP也能正常执行。需要使用MediaPlayer.setWakeMode()为MediaPlayer设定唤醒锁。以下是setWakMode()的定义:setWakeMode(Context context, int mode)第一个參数是当前上下文,第二个參数为须要加锁的状态,被设定为int类型的常量,定义在PowerManager这个final类中。在这里仅仅须要设定为PARTIAL_WAKE_LOCK就可以。
// 设定CUP锁定mediaPlayer = new MediaPlayer(); mediaPlayer.setWakeMode(getApplicationContext(), PowerManager.PARTIAL_WAKE_LOCK);
一般对于锁而言。锁定了通常须要解锁。可是这里的唤醒锁与MediaPlayer关联,所以仅仅须要在使用完之后release()释放MediaPlayer就可以,无需显式的为其解锁。在使用setWakeMode设定唤醒锁的时候,还必须为应用赋予对应的权限:
<uses-permission android:name="android.permission.WAKE_LOCK"/>
Doze模式是Android6.0上新出的一种模式,是一种全新的、低能耗的状态,在后台只有部分任务允许运行,其他都被强制停止。当用户一段时间没有使用手机的时候,Doze模式通过延缓app后台的CPU和网络活动减少电量的消耗。若手机厂商生产的定制机型中使用到该模式,需要申请将app添加进白名单,可尽量帮助鹰眼服务在后台持续运行,代码如下:
//位置采集周期// 在Android 6.0及以上系统,若定制手机使用到doze模式,请求将应用添加到白名单。if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {String packageName = trackApp.getPackageName();boolean isIgnoring = powerManager.isIgnoringBatteryOptimizations(packageName);if (!isIgnoring) {Intent intent = new Intent(Settings.ACTION_REQUEST_IGNORE_BATTERY_OPTIMIZATIONS);intent.setData(Uri.parse("package:" + packageName));try {startActivity(intent);} catch (Exception ex) {ex.printStackTrace();}}}
清单文件中添加权限声明:
//位置采集周期<uses-permission android:name="android.permission.REQUEST_IGNORE_BATTERY_OPTIMIZATIONS"/>
手机锁屏后一段时间,cpu可能会进入休眠模式,此时无法严格按照采集周期获取定位依据,导致轨迹点缺失。避免这种情况的方式是APP持有电量锁。
用户按下back键退出应用时,开发者可在MainActivity的onDestroy()方法中决定是否要继续追踪轨迹。
调用stopTrace后,将立即停止采集轨迹,对于缓存数据此时有两种情况:
上一篇
下一篇
本篇文章对您是否有帮助?