Android 适配安卓9.0,适配全面屏,Dialog或DialogFragment适配全面屏

2024-02-04 10:50

本文主要是介绍Android 适配安卓9.0,适配全面屏,Dialog或DialogFragment适配全面屏,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

检测是否异形屏,刘海屏,水滴屏的代码在最后.

安卓8.0各个手机厂商配置参数:

<!-- 全面屏 vivo/oppo o版本刘海屏配置项 --><meta-dataandroid:name="android.max_aspect"android:value="2.6" /><!-- 刘海屏华为o版本配置,如果不配置则不使用华为o系统刘海区域 --><meta-dataandroid:name="android.notch_support"android:value="true" /><!-- 刘海屏小米o版本配置,如果不配置则不使用小米o系统刘海区域 --><meta-dataandroid:name="notch.config"android:value="portrait|landscape" />

Activity适配全面屏:

在Activity中重写 onAttachedToWindow() 方法,在OnCreate方法中不生效.

/*** 生命周期 onCreate->onStart->onResume->onAttachedToWindow* 判断是否是异形屏,必须在此方法*/@Overridepublic void onAttachedToWindow() {super.onAttachedToWindow();//适配安卓Q全面屏setActivityAndroidP(this);}/*** 安卓P(9.0系统) 适配Activity页面的全屏*/public static void setActivityAndroidP(Activity activity) {//设置全屏展示if (Build.VERSION.SDK_INT >= 28) {if (activity != null && activity.getWindow() != null) {activity.getWindow().addFlags(WindowManager.LayoutParams.FLAG_LAYOUT_NO_LIMITS);//全屏显示WindowManager.LayoutParams lp = activity.getWindow().getAttributes();lp.layoutInDisplayCutoutMode = WindowManager.LayoutParams.LAYOUT_IN_DISPLAY_CUTOUT_MODE_SHORT_EDGES;activity.getWindow().setAttributes(lp);} else {PlatformLog.e("activity全屏设置失败,activity或window为空");}}}

Dialog或DialogFragment适配全面屏:

重写 onActivityCreated(Bundle savedInstanceState) 方法,在里面调用:

    @Overridepublic void onActivityCreated(Bundle savedInstanceState) {super.onActivityCreated(savedInstanceState);//适配安卓Q全面屏setDialogAndroidP(getDialog());}/*** 安卓P(9.0系统) 适配dialogFragment页面的全屏*/public static void setDialogAndroidP(Dialog dialog) {//设置全屏展示if (Build.VERSION.SDK_INT >= 28) {if (dialog != null && dialog.getWindow() != null) {dialog.getWindow().addFlags(WindowManager.LayoutParams.FLAG_LAYOUT_NO_LIMITS);//全屏显示WindowManager.LayoutParams lp = dialog.getWindow().getAttributes();lp.layoutInDisplayCutoutMode = WindowManager.LayoutParams.LAYOUT_IN_DISPLAY_CUTOUT_MODE_SHORT_EDGES;dialog.getWindow().setAttributes(lp);} else {PlatformLog.e("dialog全屏设置失败,dialog或window为空");}}}

全屏设置完之后在小米11手机上,出现了一个虚拟按键区,此区域默认黑色,跟整体屏幕很不协调,还有时不能全屏展示,解决方案如下:

Activity在 setContentView() 设置方法之前设置:

     @Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);//沉浸式getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);//设置虚拟按键的背景颜色if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {getWindow().setNavigationBarColor(Color.parseColor("#FFFF00"));}setContentView(R.layout.activity_main);
}

此代码设置在Dialog或DialogFragment中却发现虚拟按键背景颜色不生效,而且当Activity设置 如下主题也不能修改虚拟背景颜色:

 android:theme="@android:style/Theme.Translucent.NoTitleBar"android:theme="@android:style/Theme.Light.NoTitleBar.Fullscreen"

于是决定自定义主题尝试,最终成功实现效果:

1.单独设置Dialog或DialogFragment虚拟背景颜色:

在values/styles.xml中自定义:

<!--设置虚拟按键navigationBarColor属性,安卓5.0之后生效,DialogFragment在代码中设置无效--><style name="dialog_fragment_navigationBarColor_style"><item name="android:windowFullscreen">true</item></style>

创建values-v21/styles.xml,因为虚拟按键是安卓5.0推出的,直接在values/styles.xml中定义报错:

  <!--设置虚拟按键navigationBarColor属性,安卓5.0之后生效,DialogFragment在代码中设置无效--><style name="dialog_fragment_navigationBarColor_style"><!-- 下面配置来自参数二setStyle(DialogFragment.STYLE_NO_TITLE, android.R.style.Theme_Translucent_NoTitleBar_Fullscreen);--><item name="android:windowFullscreen">true</item><item name="android:navigationBarColor">#FFFFFF</item><!--虚拟按键背景,DialogFragment在代码中设置无效--></style>

 配置图片如下:

在Dialog或DialogFragment的onCreate() 方法中调用:

    @Overridepublic void onCreate(@Nullable Bundle savedInstanceState) {super.onCreate(savedInstanceState);setStyle(DialogFragment.STYLE_NO_TITLE, R.style.dialog_fragment_navigationBarColor_style);}@Overridepublic void onActivityCreated(Bundle savedInstanceState) {super.onActivityCreated(savedInstanceState);if (getDialog() != null && getDialog().getWindow() != null) {getDialog().getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);//沉浸式}}

2. 整个APP实现虚拟按键颜色:

1.在values/styles.xml中自定义:

<!--适配全面屏和底部虚拟键背景的自定义style,直接使用@android:style/Theme.Light.NoTitleBar.Fullscreen会导致底部虚拟键背景设置颜色失败--><style name="no_title_style"><item name="android:windowActionBar">false</item><item name="android:windowNoTitle">true</item><item name="android:windowFullscreen">true</item><item name="android:windowContentOverlay">@null</item></style>

2.创建values-v21/styles.xml,因为虚拟按键是安卓5.0推出的,直接在values/styles.xml中定义报错:

 <!--适配全面屏和底部虚拟键背景的自定义style,直接使用@android:style/Theme.Light.NoTitleBar.Fullscreen会导致底部虚拟键背景设置颜色失败--><style name="no_title_style"><item name="android:windowActionBar">false</item><item name="android:windowNoTitle">true</item><item name="android:windowFullscreen">true</item><item name="android:windowContentOverlay">@null</item><item name="android:navigationBarColor">#FFFF00<!--虚拟按键背景,DialogFragment在代码中设置无效--></style>

3.在Activiyt统一使用上面定义的style:

<activityandroid:name=".MainActivity"android:theme="@style/no_title_style"><intent-filter><action android:name="android.intent.action.MAIN" /><category android:name="android.intent.category.LAUNCHER" /></intent-filter></activity>

最终实现所有的Activity,Fragment,Dialog,DialogFragment 全屏显示,虚拟导航背景颜色也修改成功.

异形屏检测,见本人另外一篇博客,直接复制工具类使用即可:

https://blog.csdn.net/zhao8856234/article/details/117747273?spm=1001.2014.3001.5501

 

这篇关于Android 适配安卓9.0,适配全面屏,Dialog或DialogFragment适配全面屏的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

全面解析Golang 中的 Gorilla CORS 中间件正确用法

《全面解析Golang中的GorillaCORS中间件正确用法》Golang中使用gorilla/mux路由器配合rs/cors中间件库可以优雅地解决这个问题,然而,很多人刚开始使用时会遇到配... 目录如何让 golang 中的 Gorilla CORS 中间件正确工作一、基础依赖二、错误用法(很多人一开

Android Paging 分页加载库使用实践

《AndroidPaging分页加载库使用实践》AndroidPaging库是Jetpack组件的一部分,它提供了一套完整的解决方案来处理大型数据集的分页加载,本文将深入探讨Paging库... 目录前言一、Paging 库概述二、Paging 3 核心组件1. PagingSource2. Pager3.

深入浅出SpringBoot WebSocket构建实时应用全面指南

《深入浅出SpringBootWebSocket构建实时应用全面指南》WebSocket是一种在单个TCP连接上进行全双工通信的协议,这篇文章主要为大家详细介绍了SpringBoot如何集成WebS... 目录前言为什么需要 WebSocketWebSocket 是什么Spring Boot 如何简化 We

Spring Boot3.0新特性全面解析与应用实战

《SpringBoot3.0新特性全面解析与应用实战》SpringBoot3.0作为Spring生态系统的一个重要里程碑,带来了众多令人兴奋的新特性和改进,本文将深入解析SpringBoot3.0的... 目录核心变化概览Java版本要求提升迁移至Jakarta EE重要新特性详解1. Native Ima

全面掌握 SQL 中的 DATEDIFF函数及用法最佳实践

《全面掌握SQL中的DATEDIFF函数及用法最佳实践》本文解析DATEDIFF在不同数据库中的差异,强调其边界计算原理,探讨应用场景及陷阱,推荐根据需求选择TIMESTAMPDIFF或inte... 目录1. 核心概念:DATEDIFF 究竟在计算什么?2. 主流数据库中的 DATEDIFF 实现2.1

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期

Android ClassLoader加载机制详解

《AndroidClassLoader加载机制详解》Android的ClassLoader负责加载.dex文件,基于双亲委派模型,支持热修复和插件化,需注意类冲突、内存泄漏和兼容性问题,本文给大家介... 目录一、ClassLoader概述1.1 类加载的基本概念1.2 android与Java Class

Java操作Word文档的全面指南

《Java操作Word文档的全面指南》在Java开发中,操作Word文档是常见的业务需求,广泛应用于合同生成、报表输出、通知发布、法律文书生成、病历模板填写等场景,本文将全面介绍Java操作Word文... 目录简介段落页头与页脚页码表格图片批注文本框目录图表简介Word编程最重要的类是org.apach

Linux中SSH服务配置的全面指南

《Linux中SSH服务配置的全面指南》作为网络安全工程师,SSH(SecureShell)服务的安全配置是我们日常工作中不可忽视的重要环节,本文将从基础配置到高级安全加固,全面解析SSH服务的各项参... 目录概述基础配置详解端口与监听设置主机密钥配置认证机制强化禁用密码认证禁止root直接登录实现双因素

全面解析MySQL索引长度限制问题与解决方案

《全面解析MySQL索引长度限制问题与解决方案》MySQL对索引长度设限是为了保持高效的数据检索性能,这个限制不是MySQL的缺陷,而是数据库设计中的权衡结果,下面我们就来看看如何解决这一问题吧... 目录引言:为什么会有索引键长度问题?一、问题根源深度解析mysql索引长度限制原理实际场景示例二、五大解决