如何让Android设备实现息屏显示

2023-10-23 14:40

本文主要是介绍如何让Android设备实现息屏显示,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

什么是息屏显示?

息屏显示就是手机在息屏状态下,屏幕上会显示当前时间、日期信息,无需点亮手机屏幕即可查看。息屏显示的原理主要是利用了OLED屏幕像素点自发光的特性,仅显示时间的像素点发光,功耗相比LCD屏幕要低很多。

Android原生的主动显示

玩过Android源码的同学应该知道,在Settings里有一个开关项:
设置 - 显示 - 主动显示

这就是设置 - 显示下的主动显示选项,勾选了这个选项后,当设备在息屏时接到一条新通知会显示这样的效果:

是不是发现与息屏显示的效果一模一样,但触发条件却不一样,需要息屏后有通知才会显示出来,并且过一段时间又会自动消失回归黑屏,那么怎样才能做到像三星那样的息屏后就能一直都显示呢?

源码分析

既然知道主动显示开关是放在设置里面的,那不妨先从Settings的源码看起,首先找到主动显示对应的Preference

<Preferenceandroid:key="ambient_display"android:title="@string/ambient_display_screen_title"android:fragment="com.android.settings.display.AmbientDisplaySettings" />

然后发现在AmbientDisplaySettings里注册了一些controller

    private static List<AbstractPreferenceController> buildPreferenceControllers(Context context,Lifecycle lifecycle, AmbientDisplayConfiguration config,MetricsFeatureProvider metricsFeatureProvider,AmbientDisplayAlwaysOnPreferenceController.OnPreferenceChangedCallback aodCallback) {final List<AbstractPreferenceController> controllers = new ArrayList<>();controllers.add(new AmbientDisplayNotificationsPreferenceController(context, config,metricsFeatureProvider));controllers.add(new AmbientDisplayAlwaysOnPreferenceController(context, config,aodCallback));controllers.add(new DoubleTapScreenPreferenceController(context, lifecycle, config,MY_USER_ID, KEY_AMBIENT_DISPLAY_DOUBLE_TAP));controllers.add(new PickupGesturePreferenceController(context, lifecycle, config,MY_USER_ID, KEY_AMBIENT_DISPLAY_PICK_UP));return controllers;}

先关注里面的两个:AmbientDisplayNotificationsPreferenceController和AmbientDisplayAlwaysOnPreferenceController,看名字大概能知道,第一个与通知有关,应该是上文提到的息屏后来通知才显示;而第二个就是我们要找的“始终开启”。

AmbientDisplayAlwaysOnPreferenceController

public class AmbientDisplayAlwaysOnPreferenceController extendsAbstractPreferenceController implements PreferenceControllerMixin,Preference.OnPreferenceChangeListener {private final int ON = 1;private final int OFF = 0;...// 每次进入该PreferenceScreen都会调用一次刷新开关状态@Overridepublic void updateState(Preference preference) {((SwitchPreference) preference).setChecked(isAlwaysOnEnabled(mConfig));}// 通过AmbientDisplayConfiguration获得当前enable状态public static boolean isAlwaysOnEnabled(AmbientDisplayConfiguration config) {return config.alwaysOnEnabled(MY_USER);}// 每次点击后写入数据@Overridepublic boolean onPreferenceChange(Preference preference, Object newValue) {int enabled = (boolean) newValue ? ON : OFF;Settings.Secure.putInt(mContext.getContentResolver(), Settings.Secure.DOZE_ALWAYS_ON, enabled);if (mCallback != null) {mCallback.onPreferenceChanged();}return true;}// 该Preference是否可用@Overridepublic boolean isAvailable() {return isAvailable(mConfig);}// 通过AmbientDisplayConfiguration 获得available状态public static boolean isAvailable(AmbientDisplayConfiguration config) {return config.alwaysOnAvailableForUser(MY_USER);}...
}

分析AmbientDisplayAlwaysOnPreferenceController的源码发现,AlwaysOn的enable和available状态都需要通过AmbientDisplayConfiguration 这个类来获得,并且这个类位于framework中。

简单介绍下AmbientDisplayConfiguration 中与alwaysOn有关的几个函数:

    public boolean alwaysOnEnabled(int user) {return boolSettingDefaultOn(Settings.Secure.DOZE_ALWAYS_ON, user) && alwaysOnAvailable()&& !accessibilityInversionEnabled(user);}public boolean alwaysOnAvailable() {return (alwaysOnDisplayDebuggingEnabled() || alwaysOnDisplayAvailable())&& ambientDisplayAvailable();}private boolean alwaysOnDisplayAvailable() {return mContext.getResources().getBoolean(R.bool.config_dozeAlwaysOnDisplayAvailable);}public boolean accessibilityInversionEnabled(int user) {return boolSettingDefaultOff(Settings.Secure.ACCESSIBILITY_DISPLAY_INVERSION_ENABLED, user);}private boolean ambientDisplayAvailable() {return !TextUtils.isEmpty(ambientDisplayComponent());}public String ambientDisplayComponent() {return mContext.getResources().getString(R.string.config_dozeComponent);}private boolean boolSettingDefaultOn(String name, int user) {return boolSetting(name, user, 1);}private boolean boolSetting(String name, int user, int def) {return Settings.Secure.getIntForUser(mContext.getContentResolver(), name, def, user) != 0;}

alwaysOnAvailable为true需要同时满足两个条件:

处于debug模式,或者config_dozeAlwaysOnDisplayAvailable为true,这个值写在frameworks/base/core/res/res/values/config.xml里,默认是false;
config_dozeComponent取值不为空,这个值同样写在上面讲到的config.xml里,默认是空着的。

alwaysOnEnabled为true需要同时满足三个条件:

DOZE_ALWAYS_ON值写入了1,即Settings里开启了开关;
alwaysOnAvailable为true;
ACCESSIBILITY_DISPLAY_INVERSION_ENABLED值为0,即没有开启颜色反转。

原来源码里面默认把AlwaysOn功能给关闭了,如果想启用这个功能,需要修改config.xml里的两个值或者强制alwaysOnAvailable返回true,修改后设置里的主动显示一栏就会多出一项“始终开启”可以勾选,这样一来我们的设备在息屏之后就能自动开启主动显示功能了。

这篇关于如何让Android设备实现息屏显示的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/268500

相关文章

C/C++中OpenCV 矩阵运算的实现

《C/C++中OpenCV矩阵运算的实现》本文主要介绍了C/C++中OpenCV矩阵运算的实现,包括基本算术运算(标量与矩阵)、矩阵乘法、转置、逆矩阵、行列式、迹、范数等操作,感兴趣的可以了解一下... 目录矩阵的创建与初始化创建矩阵访问矩阵元素基本的算术运算 ➕➖✖️➗矩阵与标量运算矩阵与矩阵运算 (逐元

C/C++的OpenCV 进行图像梯度提取的几种实现

《C/C++的OpenCV进行图像梯度提取的几种实现》本文主要介绍了C/C++的OpenCV进行图像梯度提取的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录预www.chinasem.cn备知识1. 图像加载与预处理2. Sobel 算子计算 X 和 Y

C/C++和OpenCV实现调用摄像头

《C/C++和OpenCV实现调用摄像头》本文主要介绍了C/C++和OpenCV实现调用摄像头,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录准备工作1. 打开摄像头2. 读取视频帧3. 显示视频帧4. 释放资源5. 获取和设置摄像头属性

c/c++的opencv图像金字塔缩放实现

《c/c++的opencv图像金字塔缩放实现》本文主要介绍了c/c++的opencv图像金字塔缩放实现,通过对原始图像进行连续的下采样或上采样操作,生成一系列不同分辨率的图像,具有一定的参考价值,感兴... 目录图像金字塔简介图像下采样 (cv::pyrDown)图像上采样 (cv::pyrUp)C++ O

c/c++的opencv实现图片膨胀

《c/c++的opencv实现图片膨胀》图像膨胀是形态学操作,通过结构元素扩张亮区填充孔洞、连接断开部分、加粗物体,OpenCV的cv::dilate函数实现该操作,本文就来介绍一下opencv图片... 目录什么是图像膨胀?结构元素 (KerChina编程nel)OpenCV 中的 cv::dilate() 函

Python使用FFmpeg实现高效音频格式转换工具

《Python使用FFmpeg实现高效音频格式转换工具》在数字音频处理领域,音频格式转换是一项基础但至关重要的功能,本文主要为大家介绍了Python如何使用FFmpeg实现强大功能的图形化音频转换工具... 目录概述功能详解软件效果展示主界面布局转换过程截图完成提示开发步骤详解1. 环境准备2. 项目功能结

SpringBoot使用ffmpeg实现视频压缩

《SpringBoot使用ffmpeg实现视频压缩》FFmpeg是一个开源的跨平台多媒体处理工具集,用于录制,转换,编辑和流式传输音频和视频,本文将使用ffmpeg实现视频压缩功能,有需要的可以参考... 目录核心功能1.格式转换2.编解码3.音视频处理4.流媒体支持5.滤镜(Filter)安装配置linu

在Spring Boot中实现HTTPS加密通信及常见问题排查

《在SpringBoot中实现HTTPS加密通信及常见问题排查》HTTPS是HTTP的安全版本,通过SSL/TLS协议为通讯提供加密、身份验证和数据完整性保护,下面通过本文给大家介绍在SpringB... 目录一、HTTPS核心原理1.加密流程概述2.加密技术组合二、证书体系详解1、证书类型对比2. 证书获

Druid连接池实现自定义数据库密码加解密功能

《Druid连接池实现自定义数据库密码加解密功能》在现代应用开发中,数据安全是至关重要的,本文将介绍如何在​​Druid​​连接池中实现自定义的数据库密码加解密功能,有需要的小伙伴可以参考一下... 目录1. 环境准备2. 密码加密算法的选择3. 自定义 ​​DruidDataSource​​ 的密码解密3

使用Python实现Windows系统垃圾清理

《使用Python实现Windows系统垃圾清理》Windows自带的磁盘清理工具功能有限,无法深度清理各类垃圾文件,所以本文为大家介绍了如何使用Python+PyQt5开发一个Windows系统垃圾... 目录一、开发背景与工具概述1.1 为什么需要专业清理工具1.2 工具设计理念二、工具核心功能解析2.