[size=large]花了半天时间研究下了自定义锁屏,发现其实实现并不是很神秘。不过有些地方还是值得注意。
首先说流程,锁屏界面一般是在关闭屏幕时启用,打开屏幕时展现在我们面前,所以我们知道了锁屏的时机,恰好屏幕开关会发出相应的广播,所以我们也可以像系统一样捕获到屏幕开关的事件。
广播对应的两个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以后,系统锁屏就被替换成了我们自己的锁屏界面。
锁屏替换功能也就完成了。其实还可以修改系统锁屏,不过设计到框架层的修改,推广也很麻烦,所以掠过不说了。[/size]
分享到:
相关推荐
本项目“Android自定义锁屏页Demo”旨在帮助开发者理解和实现这一功能。下面我们将详细探讨Android自定义锁屏页的核心知识点以及如何通过这个Demo进行实践。 1. **Activity与Window** 自定义锁屏页面本质上是创建...
在Android系统中,自定义锁屏界面是一种常见的需求,它能提供更加个性化或者增强安全性的体验。本篇文章将深入探讨如何实现一个自定义锁屏界面,并使其能够在系统锁屏之上运行,即凌驾于系统锁屏之上。我们将讨论...
Android 自定义锁屏实现原理 Android 自定义锁屏是指在 Android 系统中,开发者可以根据自己的需求,设计和实现一个自定义的锁屏界面,以满足不同的应用场景。下面是 Android 自定义锁屏的实现原理。 锁屏服务的...
"Android自定义锁屏实现----仿正点闹钟滑屏解锁"这一主题,旨在教你如何创建一个类似“正点闹钟”应用中的滑动解锁功能。下面将详细解释实现这个功能所需的知识点: 1. **Android权限**:首先,你需要在...
在Android开发中,自定义锁屏是一项常见的需求,它可以为用户提供独特的交互体验或者增强应用程序的安全性。本篇文章将深入探讨如何实现自定义锁屏,并基于提供的"自定义View"标签和相关链接,来讲解其中涉及的关键...
这个"安卓Android源码——Android自定义锁屏实现----仿正点闹钟.zip"压缩包文件提供了一个实例,展示了如何模仿“正点闹钟”的锁屏功能。通过分析和学习这个源码,我们可以了解到Android系统的锁屏机制以及如何进行...
"Android应用源码-Android自定义锁屏实现----仿正点闹钟.zip"是一个示例项目,旨在展示如何创建一个类似“正点闹钟”的自定义锁屏界面。通过分析这个压缩包中的源码,我们可以学习到以下关键知识点: 1. **自定义...
该资源是一个关于Android应用开发的源码包,主要聚焦于自定义锁屏界面的实现,模仿了"正点闹钟"的设计。对于Android开发者来说,这是一个极好的学习和实践平台,能够深入理解Android系统的UI定制以及交互逻辑。下面...
在Android编程中,自定义锁屏是一项常见的需求,它允许开发者根据特定的用户需求或应用场景创建独特的用户体验。本文将深入探讨如何实现自定义锁屏,包括理解锁屏的工作原理、捕获屏幕状态改变的广播以及确保服务...
Android应用源码开发Demo,主要用于毕业设计学习。
在Android系统中,锁屏是用户与...以上内容详细介绍了Android自定义锁屏的实现,包括开机自启动和屏蔽系统锁屏的步骤,希望对你的Android开发工作有所帮助。在实际应用中,务必根据项目需求和用户习惯进行优化调整。
自定义锁屏涉及到对Android系统的深入理解,包括Activity管理、窗口管理、权限控制以及用户交互设计等多个方面。以下是对这个主题的详细阐述: 1. **启动器与锁屏界面** 安卓系统的启动器(Launcher)是用户与设备...
通过分析锁屏启动流程,开发者可以更好地理解如何在不同场景下控制锁屏的显示和行为,从而实现自定义的锁屏功能。此外,熟悉这一过程还能帮助解决与锁屏相关的问题,提高用户体验。 总的来说,Android 10.0的锁屏...