android系统对应用长时间运行的要求日趋严格,轨迹追踪应用可能会被系统杀死,导致轨迹上传不完整。我们梳理了有助于android app保活方法,供开发者参考。同时,开发者应在严格遵守《百度地图开放平台产品和服务隐私政策》并保证应用合法合规的前提下使用百度鹰眼服务。
方法一:开发者自行向华为申请加入后台app白名单,加入白名单后具体申请方法可详询华为客服。以下提供过往开发者的经验供参考,但最终解释权为华为所有:
方法二:android 8.0系统为实现降低功耗,会对后台应用获取用户当前位置的频率进行限制,只允许后台应用每小时接收几次位置更新。为了适配这一系统特性,开发者可以参考鹰眼demo,生成一个前台服务通知,使得应用退到后台的时候,仍有前台通知在,从而规避android 8.0系统对后台定位的限制。
核心代码如下:
notification.builder builder =newnotification.builder(this);intent notificationintent =newintent(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 =newnotificationchannel("trace","trace_channel",notificationmanager.importance_high);notificationmanager.createnotificationchannel(notificationchannel);builder.setchannelid("trace");// android ochannelid}notification = builder.build();// notificationnotification.defaults=notification.default_sound;//lbstraceclient mclient =newlbstraceclient(mcontext);trace mtrace =newtrace(serviceid, entityname);mtrace.setnotification(notification);
通过上述方式开启前台服务后无需开发者手动释放,鹰眼sdk内部会随着停止鹰眼服务一并释放。开启前台服务在其他版本android系统中使用也可最大程度的增加定位进程的存活率,提升后台定位效果。
注意:在android 8.0之后使用前台服务,需要申请以下权限:
<uses-permission android:name="android.permission.foreground_service"/>
android 10.0系统对定位限制更新严格,新增了后台定位权限,如果应用退到后台仍需定位,需要申请以下权限:
<uses-permissionandroid: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 =newmediaplayer(); 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 =newintent(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后,将立即停止采集轨迹,对于缓存数据此时有两种情况:
上一篇
下一篇
本篇文章对您是否有帮助?