转载请表明出处http://blog.csdn.net/wdaming1986/article/details/8837023

好了,言归正传,说说锁屏了,其实把锁屏做成apk的形式,会引起很多问题的,导致不必要的麻烦,就像市场上的流行的Go锁屏和91锁屏也是会有一些问题的,只是影响不大,最好的做法是修改源码,在源码中定制自己的锁屏,这样一劳永逸;

首先做锁屏考虑的事有以下四点;

(1)替换掉系统的锁屏,不能让系统的锁屏显示出来;

        (2)屏蔽掉Home键盘,back键,menu键;

        (3)在其他界面或Launcher界面,长按home键,不能让自己的锁屏apk显示在最近任务中;

        (4)每次开机显示自己的锁屏

针对这四点一一做解答,不一定是完整的代码,只是提供以下思路,有兴趣的同学可以提出疑问;

针对(1),这个比较容易,就调用disableKeyguard掉系统的就可以了;

  1. mKeyguardManager = (KeyguardManager)Class.this.getSystemService(Context.KEYGUARD_SERVICE);
  2. mKeyguardLock = mKeyguardManager.newKeyguardLock("my_lockscreen");
  3. mKeyguardLock.disableKeyguard();

注意:在Manifext.xml中加入权限:

<uses-permission android:name="android.permission.DISABLE_KEYGUARD"/>

针对(2),这个Home键的处理,我看网上有同学写博客了,有同学这么处理:

  1. public class LockLayer {
  2. private Activity mActivty;
  3. private WindowManager mWindowManager;
  4. private View mLockView;
  5. private LayoutParams mLockViewLayoutParams;
  6. private static LockLayer mLockLayer;
  7. private boolean isLocked;
  8. public static synchronized LockLayer getInstance(Activity act){
  9. if(mLockLayer == null){
  10. mLockLayer = new LockLayer(act);
  11. }
  12. return mLockLayer;
  13. }
  14. private LockLayer(Activity act) {
  15. mActivty = act;
  16. init();
  17. }
  18. private void init(){
  19. isLocked = false;
  20. mWindowManager = mActivty.getWindowManager();
  21. mLockViewLayoutParams = new LayoutParams();
  22. mLockViewLayoutParams.width = LayoutParams.MATCH_PARENT;
  23. mLockViewLayoutParams.height = LayoutParams.MATCH_PARENT;
  24. //实现关键
  25. mLockViewLayoutParams.type = LayoutParams.TYPE_SYSTEM_ERROR;
  26. //apktool value,这个值具体是哪个变量还请网友帮忙
  27. mLockViewLayoutParams.flags = 1280;
  28. }
  29. public synchronized void lock() {
  30. if(mLockView!=null&&!isLocked){
  31. mWindowManager.addView(mLockView, mLockViewLayoutParams);
  32. }
  33. isLocked = true;
  34. }
  35. public synchronized void unlock() {
  36. if(mWindowManager!=null&&isLocked){
  37. mWindowManager.removeView(mLockView);
  38. }
  39. isLocked = false;
  40. }
  41. public synchronized void setLockView(View v){
  42. mLockView = v;
  43. }
  44. }

原理:是把这个view当成系统的错误的view,

这个在PhoneWindowManager.java中的interceptKeyBeforeDispatching()方法中也有根据,请看真相:

  1. final int typeCount = WINDOW_TYPES_WHERE_HOME_DOESNT_WORK.length;
  2. for (int i=0; i<typeCount; i++) {
  3. if (type == WINDOW_TYPES_WHERE_HOME_DOESNT_WORK[i]) {
  4. // don't do anything, but also don't pass it to the app
  5. return -1;
  6. }
  7. }

看注释:如果设置了这两个属性的其中一个,就不做任何处理,home键不对这个app生效;

而WINDOW_TYPES_WHERE_HOME_DOESNT_WORK数据的定义如下:

  1. private static final int[] WINDOW_TYPES_WHERE_HOME_DOESNT_WORK = {
  2. WindowManager.LayoutParams.TYPE_SYSTEM_ALERT,
  3. WindowManager.LayoutParams.TYPE_SYSTEM_ERROR,
  4. };

这下你就明白为什么上述代码设置为TYPE_SYSTEM_ERROR,其实设置为TYPE_SYSTEM_ALERT也可以的。

再来看看sdk文档有解释说明,

Window type: internal system error windows, appear on top of everything they can. In multiuser systems shows only on the owning user's window.

这个error的view在所有的view的最上面,所以就可以达到屏蔽home键的效果了;

问题来了:在这个界面长按power键,关机界面也弹不出来了,这个我试验过,所以这个方法不可取;

还有同学说这么做:

private static final int FLAG_HOMEKEY_DISPATCHED = 0x80000000;

  1. 在app 的你要屏蔽home 键的activity 中,只需要添加该标志就可以了
  2. this.getWindow().setFlags(FLAG_HOMEKEY_DISPATCHED, FLAG_HOMEKEY_DISPATCHED);
  3. 如果要使home 键有效,再 clearFlags 即可。
  4. getWindow().clearFlags(WindowManager.LayoutParams.FLAG_HOMEKEY_DISPATCHED);

注意:以上代码要加在setContentView()之前才行;

这个代码来源于PhoneWindowManager.java这个类的interceptKeyBeforeDispatching()方法中,

  1. if ((flag & WindowManager.LayoutParams.FLAG_HOMEKEY_DISPATCHED) != 0) {
  2. // the window wants to handle the home key, so dispatch it to it.
  3. return 0;
  4. }

这样设置,有的同学感觉好用,有的同学感觉不好用;

原因:android4.0的源码的PhoneWindowManager.java没有添加上述代码,所以不起作用,

而4.1的源码PhoneWindowManager.java中有这个代码,所以好用,这个请大家看看对应的源码是否有上述代码;

针对(3),这个就模仿Go锁屏和91锁屏,在启动锁屏的activity中配置

  1. <category android:name="android.intent.category.HOME" />

这个属性,然后先清除系统启动的默认设置,就是选择系统点击Home键启动哪个home,设置为启动自己的锁屏,然后再设置解锁后启动那个桌面,这个自己处理下逻辑就可以了,大致思路就是这个样子的;

针对(4),这个Go锁屏还有91锁屏处理的都不太理想,回头我想到好的思路再更新,大致思路是:监听开机广播, <action android:name="android.intent.action.BOOT_COMPLETED"/>,这个写一个MYBootCompletedReceiver类,作用是disable掉系统的锁屏,然后启动自己的锁屏的服务,监听屏幕亮和灭的广播,这个屏幕亮和灭的广播要动态监听;大家有好的思路或见解可以留言讨论?

最新文章

  1. 【Java心得总结七】Java容器下——Map
  2. 总结CSS3新特性(Animation篇)
  3. hive 使用笔记(table format;lateral view)
  4. 【转】【C/C++】实现memcpy函数
  5. “数学口袋精灵”第二个Sprint计划(第十天)总结
  6. [原创]移动应用测试技术圈QQ群:211828629
  7. 新增WiFi真机同步与实时预览功能 简化真机调试步骤
  8. Codeforces 533B Work Group
  9. DOM querySelector选择器
  10. &lt;当幸福来敲门&gt;之一些很喜欢的台词收藏
  11. mpvue-Vant Weapp踩坑记
  12. ORA-600 [kcblin_3] 解决方法
  13. 【转】Git 教程之协同开发
  14. React 60S倒计时
  15. 虚拟机上不能使用CUDA
  16. EBS 系统当前完成请求时间监测
  17. Codeforces Round #224 (Div. 2) A. Ksenia and Pan Scales
  18. POJ3045 Cow Acrobats 2017-05-11 18:06 31人阅读 评论(0) 收藏
  19. 教你用DrawLayout 实现Android 侧滑菜单
  20. 标准Trie字典树学习二:Java实现方式之一

热门文章

  1. 网络编程----socket介绍、基于tcp协议的套接字实现、基于udp协议的套接字实现
  2. unity直连android真机在Profiler性能分析测试
  3. vim正则表达式小结
  4. 小程序navigatorTo缺点和修正方法
  5. 第1章-初识Vue.js
  6. 源码包安装 NGINX时候遇到的错误以及解决办法!
  7. JS函数表达的几种写法
  8. JobEngine 基于quartz.net 跨平台作业框架
  9. 在eclipse安装mybatis的插件
  10. 去掉input获取focus时的边框