安卓系统home键监听及系统锁屏状态监听___Android提高篇

简介: 安卓系统home键监听及系统锁屏状态监听___Android提高篇

1.简介


最近,在做app手势密码的时候,涉及到需要监听安卓系统的Home键及系统锁屏的状态,写了一个工具类。

在做这部分处理的时候,需要发广播BroadcastReceiver,并考虑不同状态下Activity的生命周期,逻辑细节需要特别注意。至于监听的实现方式很简单就不赘述了。下面,我只给出相关的广播监听和使用方法,具体开发,还要视情况编写代码。


1)Home键:


Android中可以通过OnKeyDown(int keyCode,KeyEvent event);事件来监听系统按键,eg:KEYCODE_BACK(后退),KEYCODE_MENU(菜单)等,尽管提供了KEYCODE_HOME的监听,但实际上却接收不到,这是因为Home键 可以将程序退出至后台,因此会将这个事件分发给系统,由系统再进行相应的处理,所以在app应用中是接收不到该事件的。


实际开发时需要发广播,监测它的动作Action:

Intent.ACTION_CLOSE_SYSTEM_DIALOGS

Note:这里涉及到安卓适配问题,不同手机系统action码不一样,具体代码请看后面的代码示例。


2)系统锁屏状态监测:


有三种屏幕状态,监测动作Action分别为:

Intent.ACTION_SCREEN_ON: // 开屏状态

Intent.ACTION_SCREEN_OFF:// 锁屏状态

Intent.ACTION_USER_PRESENT:// 手机系统解锁

Note:需要特别注意的是,是否锁屏状态,需要单独判断一下,方法不唯一,我只给出一种实现方式,代码如下:

PowerManager manager = (PowerManager) mContext
                .getSystemService(Context.POWER_SERVICE);//此处的上下文是通过监听类传过来的,具体代码请看后面的完整代码示例
        if (manager.isScreenOn()) {
           //开屏
        } else {
           //锁屏
        }

2.代码示例:


1)工具类代码

eg:

/**
 * @ 莫若吻
 * @description home键监测、系统锁屏状态监
 */
public class BroadcastReceiverListener {
    private Context mContext;
    private ScreenBroadcastReceiver screenReceiver;
    private ScreenStateListener screenStateListener;
    /*
     * Home 键
     */
    private static final String SYSTEM_DIALOG_REASON_KEY = "reason";
    private static final String SYSTEM_DIALOG_REASON_RECENT_APPS = "recentapps";
    private static final String SYSTEM_DIALOG_REASON_HOME_KEY = "homekey";
    private static final String SYSTEM_DIALOG_REASON_LOCK = "lock";
    private static final String SYSTEM_DIALOG_REASON_ASSIST = "assist";
    public BroadcastReceiverListener(Context context) {
        mContext = context;
        screenReceiver = new ScreenBroadcastReceiver();
    }
    /**
     * 广播接收者
     */
    private class ScreenBroadcastReceiver extends BroadcastReceiver {
        private String action = null;
        @Override
        public void onReceive(Context context, Intent intent) {
            action = intent.getAction();
            switch (action){
                case Intent.ACTION_SCREEN_ON: // 开屏
                    screenStateListener.onScreenOn();
                    break;
                case Intent.ACTION_SCREEN_OFF:// 锁屏
                    screenStateListener.onScreenOff();
                    break;
                case Intent.ACTION_USER_PRESENT:// 解锁
                    screenStateListener.onUserPresent();
                    break;
                case Intent.ACTION_CLOSE_SYSTEM_DIALOGS://home键监测
                    /*
                    * 这里监听了手机系统按下home键的那一刻事件,
                    * 如果想再处理再次回到app应用的事物,请参考home键及应用重新启动的过程生命周期,根据实际需求进行相关的操作的。
                    */
                    setHomeListener(intent);
                    break;
                default:
                    break;
            }
        }
    }
    private void setHomeListener(Intent intent) {
        String reason = intent.getStringExtra(SYSTEM_DIALOG_REASON_KEY);
        LogUtils.e("Receiver reason: " + reason);
        switch (reason){//以下判断多个条件是为了不同安卓手机系统做适配
            case SYSTEM_DIALOG_REASON_HOME_KEY: // 短按Home键
            case SYSTEM_DIALOG_REASON_RECENT_APPS:  // 长按Home键 或者 activity切换键
            case SYSTEM_DIALOG_REASON_LOCK: // 锁屏
            case SYSTEM_DIALOG_REASON_ASSIST: // samsung 长按Home键
                screenStateListener.onHome();
                break;
            default:
                break;
        }
    }
    /**
     * 开始监听screen状态
     * @param listener
     */
    public void start(ScreenStateListener listener) {
        screenStateListener = listener;
        registerBroadcastReceiver();
        getScreenState();
    }
    /**
     * 获取screen状态
     */
    private void getScreenState() {
        PowerManager manager = (PowerManager) mContext
                .getSystemService(Context.POWER_SERVICE);
        if (manager.isScreenOn()) {
            if (screenStateListener != null) {
                screenStateListener.onScreenOn();
            }
        } else {
            if (screenStateListener != null) {
                screenStateListener.onScreenOff();
            }
        }
    }
    /**
     * 停止监听,销毁广播
     */
    public void unregisterBroadcastReceiver() {
        mContext.unregisterReceiver(screenReceiver);
    }
    /**
     * 启动screen状态和home键的广播接收器
     */
    private void registerBroadcastReceiver() {
        IntentFilter filter = new IntentFilter();
        filter.addAction(Intent.ACTION_SCREEN_ON);
        filter.addAction(Intent.ACTION_SCREEN_OFF);
        filter.addAction(Intent.ACTION_USER_PRESENT);
        filter.addAction(Intent.ACTION_CLOSE_SYSTEM_DIALOGS);
        mContext.registerReceiver(screenReceiver, filter);
    }
    public interface ScreenStateListener {// 返回给调用者屏幕状态信息
        public void onScreenOn();
        public void onScreenOff();
        public void onUserPresent();
        public void onHome();
    }
}

2)在类中的使用方式


首先,将监听工具类声明为成员变量,因为最后需要将广播销毁。

private BroadcastReceiverListener screenListener;

然后,监听一般在Activity的onCreate()方法中调用setScreenListener();方法即可,代码如下:

private void setScreenListener() {
        screenListener=new BroadcastReceiverListener(MeBaseActivity.this);
        screenListener.start(new BroadcastReceiverListener.ScreenStateListener() {
            @Override
            public void onScreenOn() {// 开屏
            }
            @Override
            public void onScreenOff() {// 锁屏
                //你的业务逻辑
            }
            @Override
            public void onUserPresent() {// 解锁
                //你的业务逻辑
            }
            @Override
            public void onHome() {//home主页键
                //你的业务逻辑
            }
        });
    }


最后,在onDestroy()中销毁广播(即监听)


@Override
    protected void onDestroy() {
        screenListener.unregisterBroadcastReceiver();
        super.onDestroy();
    }


Note:

如果你是处理Home键的相关逻辑问题,需要注意当你按下home键后,后台未销毁app时,再次启动app需要做相关的逻辑处理时,建议在onRestart()中处理页面逻辑。请注意这不是绝对的,还要根据实际业务需求去判断在哪个生命周期状态做开发。


版权声明:本文为博主原创文章,转载请必须注明出处,谢谢!



目录
相关文章
|
2月前
|
人工智能 搜索推荐 物联网
Android系统版本演进与未来展望####
本文深入探讨了Android操作系统从诞生至今的发展历程,详细阐述了其关键版本迭代带来的创新特性、用户体验提升及对全球移动生态系统的影响。通过对Android历史版本的回顾与分析,本文旨在揭示其成功背后的驱动力,并展望未来Android可能的发展趋势与面临的挑战,为读者呈现一个既全面又具深度的技术视角。 ####
|
16天前
|
存储 监控 API
app开发之安卓Android+苹果ios打包所有权限对应解释列表【长期更新】-以及默认打包自动添加权限列表和简化后的基本打包权限列表以uniapp为例-优雅草央千澈
app开发之安卓Android+苹果ios打包所有权限对应解释列表【长期更新】-以及默认打包自动添加权限列表和简化后的基本打包权限列表以uniapp为例-优雅草央千澈
|
2月前
|
IDE Java 开发工具
移动应用与系统:探索Android开发之旅
在这篇文章中,我们将深入探讨Android开发的各个方面,从基础知识到高级技术。我们将通过代码示例和案例分析,帮助读者更好地理解和掌握Android开发。无论你是初学者还是有经验的开发者,这篇文章都将为你提供有价值的信息和技巧。让我们一起开启Android开发的旅程吧!
|
1月前
|
监控 Java Android开发
深入探索Android系统的内存管理机制
本文旨在全面解析Android系统的内存管理机制,包括其工作原理、常见问题及其解决方案。通过对Android内存模型的深入分析,本文将帮助开发者更好地理解内存分配、回收以及优化策略,从而提高应用性能和用户体验。
|
1月前
|
存储 安全 Android开发
探索Android系统的最新安全特性
在数字时代,智能手机已成为我们生活中不可或缺的一部分。随着技术的不断进步,手机操作系统的安全性也越来越受到重视。本文将深入探讨Android系统最新的安全特性,包括其设计理念、实施方式以及对用户的影响。通过分析这些安全措施如何保护用户免受恶意软件和网络攻击的威胁,我们希望为读者提供对Android安全性的全面了解。
|
2月前
|
监控 Java Android开发
深入探讨Android系统的内存管理机制
本文将深入分析Android系统的内存管理机制,包括其内存分配、回收策略以及常见的内存泄漏问题。通过对这些方面的详细讨论,读者可以更好地理解Android系统如何高效地管理内存资源,从而提高应用程序的性能和稳定性。
96 16
|
2月前
|
安全 Android开发 iOS开发
深入探讨Android与iOS系统的差异及未来发展趋势
本文旨在深入分析Android和iOS两大移动操作系统的核心技术差异、用户体验以及各自的市场表现,进一步探讨它们在未来技术革新中可能的发展方向。通过对比两者的开放性、安全性、生态系统等方面,本文揭示了两大系统在移动设备市场中的竞争态势和潜在变革。
|
Android开发
Android 仿音乐播放器自定义锁屏歌词功能
在平常使用音乐播放器时经常会遇到锁屏会显示歌词功能,做的时候也是各种手机不适配,翻阅了网上的文章,发现都是好几年前的,适配的安卓版本比较低,所以我就整合了一下分享给大家.
Android 仿音乐播放器自定义锁屏歌词功能
|
Java Android开发
android 自定义 锁屏
引用:http://wiseideal.iteye.com/blog/1226380 [size=large]花了半天时间研究下了自定义锁屏,发现其实实现并不是很神秘。不过有些地方还是值得注意。 首先说流程,锁屏界面一般是在关闭屏幕时启用,打开屏幕时展现在我们面前,所以我们知道了锁屏的时机,恰好屏幕开关会发出相应的广播,所以我们也可以像系统一样捕获到屏幕开关的事件。
1171 0
|
1月前
|
搜索推荐 前端开发 API
探索安卓开发中的自定义视图:打造个性化用户界面
在安卓应用开发的广阔天地中,自定义视图是一块神奇的画布,让开发者能够突破标准控件的限制,绘制出独一无二的用户界面。本文将带你走进自定义视图的世界,从基础概念到实战技巧,逐步揭示如何在安卓平台上创建和运用自定义视图来提升用户体验。无论你是初学者还是有一定经验的开发者,这篇文章都将为你打开新的视野,让你的应用在众多同质化产品中脱颖而出。
61 19

热门文章

最新文章