实现安卓widget不被kill的方法
来源:互联网 发布:加油软件 编辑:程序博客网 时间:2024/05/18 02:02
widget本身是不会被kill的,widget原本就是一个broadcastreciver,而且是静态的,这就意味着随时发一个订阅过的广播widget都能收到,并且会调用onReceive()方法。widget之所以不能运行了,往往是应为对应的service被kill。要想widget一直运行就要使service被kill了可以重启,service杀不死的方法很多,如:
Service是android 系统中的一种组件,它跟Activity的级别差不多,但是他不能自己运行,只能后台运行,并且可以和其他组件进行交互。
Android开发的过程中,每次调用startService(Intent)的时候,都会调用该Service对象的onStartCommand(Intent,int,int)方法,然后在onStartCommand方法中做一些处理。
从Android官方文档中,我们知道onStartCommand有4种int返回值,首先简单地讲讲int返回值的作用。
一、onStartCommand有4种返回值:
START_STICKY:如果service进程被kill掉,保留service的状态为开始状态,但不保留递送的intent对象。随后系统会尝试重新创建service,由于服务状态为开始状态,所以创建服务后一定会调用onStartCommand(Intent,int,int)方法。如果在此期间没有任何启动命令被传递到service,那么参数Intent将为null。
START_NOT_STICKY:“非粘性的”。使用这个返回值时,如果在执行完onStartCommand后,服务被异常kill掉,系统不会自动重启该服务。
START_REDELIVER_INTENT:重传Intent。使用这个返回值时,如果在执行完onStartCommand后,服务被异常kill掉,系统会自动重启该服务,并将Intent的值传入。
START_STICKY_COMPATIBILITY:START_STICKY的兼容版本,但不保证服务被kill后一定能重启。
二、创建不被杀死的service
1.在service中重写下面的方法,这个方法有三个返回值, START_STICKY(或START_STICKY_COMPATIBILITY)是service被kill掉后自动重写创建
@Override public int onStartCommand(Intent intent, int flags, int startId) { return START_STICKY_COMPATIBILITY; //return super.onStartCommand(intent, flags, startId); }@Override public int onStartCommand(Intent intent, int flags, int startId) { flags = START_STICKY; return super.onStartCommand(intent, flags, startId); // return START_REDELIVER_INTENT; }@Overridepublic void onStart(Intent intent, int startId){// 再次动态注册广播IntentFilter localIntentFilter = new IntentFilter("android.intent.action.USER_PRESENT");localIntentFilter.setPriority(Integer.MAX_VALUE);// 整形最大值myReceiver searchReceiver = new myReceiver();registerReceiver(searchReceiver, localIntentFilter);super.onStart(intent, startId);}
2.在Service的onDestroy()中重启Service.
public void onDestroy(){Intent localIntent = new Intent();localIntent.setClass(this, MyService.class); // 销毁时重新启动Servicethis.startService(localIntent);}
3.创建一个广播
public class myReceiver extends BroadcastReceiver{ @Override public void onReceive(Context context, Intent intent) { context.startService(new Intent(context, Google.class)); }}
4.AndroidManifest.xml中注册广播myReceiver及MyService服务
<receiver android:name=".myReceiver" > <intent-filter android:priority="2147483647" ><!--优先级加最高--> <!-- 系统启动完成后会调用 --> <action android:name="android.intent.action.BOOT_COMPLETED" /> <!-- 解锁完成后会调用 --> <action android:name="android.intent.action.USER_PRESENT" /> <!-- 监听情景切换 --> <action android:name="android.media.RINGER_MODE_CHANGED" /> </intent-filter></receiver><service android:name=".MyService" >
注:解锁,启动,切换场景激活广播需加权限,如启动完成,及手机机状态等。
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" /><uses-permission android:name="android.permission.READ_PHONE_STATE" />
这种方法确实可以是服务不被,但是会显得很流氓,当widget从桌面移除了,service还在运行,下面是改进的方法:
1.配置xml:
application节点下配置
<receiver android:name="com.tarena.karen.widdget.TimeWidget" > <intent-filter android:priority="2147483647"> <!-- 系统启动完成后会调用 --> <action android:name="android.intent.action.BOOT_COMPLETED" /> <!-- 解锁完成后会调用 --> <action android:name="android.intent.action.USER_PRESENT" /> <!-- 监听情景切换 --> <action android:name="android.media.RINGER_MODE_CHANGED" /> <!-- 服务销毁的时候发送 --> <action android:name="com.tony.inzone.restart" /> <action android:name="android.appwidget.action.APPWIDGET_UPDATE" /> </intent-filter> <meta-data android:name="android.appwidget.provider" android:resource="@xml/widget_info" /> </receiver>
2.服务被销毁时候给widget发送一个广播
@Overridepublic void onDestroy() { timer.cancel(); timer = null; super.onDestroy(); Intent localIntent = new Intent(); localIntent.setAction("com.tony.inzone.restart"); sendBroadcast(localIntent);}
3.收到服务被系统回收/系统启动完成/解锁完成/监听情景切换 等情况
widget中再次启动服务
/** * 订阅的广播发来的时候回调 */ @Override public void onReceive(Context context, Intent intent) { super.onReceive(context, intent); Intent intent2=new Intent(context,WidgetService.class); context.startService(intent2); }
widget被移除时销毁程序,service不会重启
/** * 同种类型的最后一个小组件被删除时回调 */ @Override public void onDisabled(Context context) { super.onDisabled(context); Log.i("TAG", "onDisabled"); Intent intent=new Intent(context, WidgetService.class); context.stopService(intent); }
案例基础点击这里
- 实现安卓widget不被kill的方法
- android service不被kill的方法
- 保持Service不被Kill掉的方法--双Service守护 && Android实现双进程守护
- 保持Service不被Kill掉的方法--双Service守护 && Android实现双进程守护
- 保持Service不被Kill掉的方法--双Service守护 && Android实现双进程守护
- 安卓widget的详解
- ios后台执行不被kill的方法
- 实际应用中Service不被Kill掉的方法
- android中实现不被kill的service
- android 服务不被kill方法收集
- service能否实现不被Kill
- 【安卓笔记】Widget
- 安卓常用 widget
- ios,安卓实现video小屏播放,不全屏播放的方法
- Android应用被killed时,Service不被一起kill的方法
- android--Service自动重启而不被kill掉的一些方法
- android--Service自动重启而不被kill掉的一些方法
- 安卓双向滑动的实现方法
- JavaScript 之arguments、caller 和 callee 介绍
- 第四周项目四 猴子选大王
- 用C++输出九九乘法表(附带makefile文件)
- C语言DAY01 - 学习前奏
- 栈
- 实现安卓widget不被kill的方法
- Mybatis使用小结
- 曼彻斯特编码
- res下的 drawable 是如何解析成 Drawable 对象?
- 栈(一)
- 注册广播接收者两种方式的区别,及优缺点
- CV牛人的主页
- [kuangbin带你飞]专题七 线段树 I HDU 1540
- go go