欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  移动技术

Android编程之自定义锁屏实例分析

程序员文章站 2023-12-16 18:58:16
本文实例讲述了android编程之自定义锁屏。分享给大家供大家参考,具体如下: 花了半天时间研究下了自定义锁屏,发现其实实现并不是很神秘。不过有些地方还是值得注意。 首...

本文实例讲述了android编程之自定义锁屏。分享给大家供大家参考,具体如下:

花了半天时间研究下了自定义锁屏,发现其实实现并不是很神秘。不过有些地方还是值得注意。

首先说流程,锁屏界面一般是在关闭屏幕时启用,打开屏幕时展现在我们面前,所以我们知道了锁屏的时机,恰好屏幕开关会发出相应的广播,所以我们也可以像系统一样捕获到屏幕开关的事件。

广播对应的两个action

引用

android.intent.action.screen_on
android.intent.action.screen_off

有趣的是我在我的me860上还看到了两个广播

引用

android.intent.action.batteryprofile.scr_off
android.intent.action.batteryprofile.scr_on

这可能是moto自己定义的广播,看大家需要了。

如果单单只截获到广播,锁屏的界面怎么替换系统锁屏呢?其实我们这里并没有替换掉系统锁屏,只是我们自己的锁屏开启了系统锁屏,从而达到了一个替换的效果。

这里还是要注意点,上述action不能在androidmanifest.xml中注册,不能触发。所以这里我采用的方法是放在一个service中动态注册,截获广播正常。

这里还顺带提下service防杀的功能,因为service的进程如果不存在了,那么屏幕开关的广播是无论如何也接收不到的。

如果是系统回收掉的service,系统会在过段时间,资源充足的情况下再启动起来,不过我们可不想自己的service坐冷板凳,所以对付系统关闭service我们采取如下方法。

在service生命周期中:

intent startintent=null;
@override
 public void onstart(intent intent, int startid) {
  startintent=intent;
  intentfilter filter=new intentfilter();
  filter.addaction(intent.action_screen_on);
  filter.addaction(intent.action_screen_off);
  receiver=new relativebroadcastreceiver();
  registerreceiver(receiver, filter);
  system.out.println("service onstart and action is "+intent.getaction());
  system.out.println("service onstart and startid is "+startid);
 };
 @override
 public void ondestroy() {
  // todo auto-generated method stub
  system.out.println("service ondestroy");
  unregisterreceiver(receiver);
  if(startintent!=null){
   system.out.println("serviceintent not null");
   startservice(startintent);
  }

我们保留了开启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程序设计有所帮助。

上一篇:

下一篇: