我们保留了开启service的intent,当进入ondestroy周期中时再启动一次自己,系统看到你这劲头也只好答应你常驻内存了。
不过如果是一些内存管理软件杀掉了程序进程,以上方法就没用了,我们还是可以通过截获一些关键广播来启动自己的service,类似91助手等就是这样。可以监听wifi连接,电池电量发生变化等广播来启动自己的service。
保证自己的service常驻,这时候就该我们自己的广播接收器发挥作用了。
@Override
public void onReceive(Context context, Intent intent) {
// TODO Auto-generated method stub
String action=intent.getAction();
System.out.println("action is "+action);
Intent lockIntent=new Intent(context,MyLockScreen.class);
lockIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
context.startActivity(lockIntent);
}
需要加上lockIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);没有加的时候系统会报错,但是加上以后也有问题,这会导致多次退出才能退出自定义的锁屏界面。
其实可以自定义一个stack来管理这些activity,有其他办法的同学请提示我改正。
启动了一个activity以后我们发现还是原来的锁屏界面,这也是前面提到的,我们的锁屏需要打开系统锁屏。
打开系统锁屏:
super.onCreate(savedInstanceState); getWindow().addFlags(WindowManager.LayoutParams.FLAG_SHOW_WHEN_LOCKED); getWindow().addFlags(WindowManager.LayoutParams.FLAG_DISMISS_KEYGUARD); setContentView(R.layout.main);
添加了这两个flag以后,系统锁屏就被替换成了我们自己的锁屏界面。
锁屏替换功能也就完成了。其实还可以修改系统锁屏,不过设计到框架层的修改,推广也很麻烦,所以掠过不说了。
希望本文所述对大家Android程序设计有所帮助。
注:相关教程知识阅读请移步到Android开发频道。










