欢迎来到代码驿站!

Android代码

当前位置:首页 > 移动开发 > Android代码

Android 虚拟按键与沉浸式的适配方法

时间:2021-02-19 15:21:37|栏目:Android代码|点击:

根据公司产品的要求,app要实现全屏模式,也就是4.4以后的所谓的沉浸式。

在values-v19和values-v21的styles里添加以下代码,实现19以上的系统的沉浸式:

<style name="AppBaseTheme" parent="android:Theme.Holo.Light.NoActionBar.TranslucentDecor">
 <item name="android:windowTranslucentStatus">true</item>
 <item name="android:windowTranslucentNavigation">true</item>
 <item name="android:windowContentOverlay">@null</item>
 <item name="android:statusBarColor">@android:color/transparent</item>
</style>

TranslucentDecor,是KitKat及以上版本加入的theme包,用于把布局顶到状态栏(Status Bar)和导航栏(Navigation Bar)上,扩展屏幕高度。这样,只要我们把Status Bar和Navigation Bar的颜色设置成透明,那就可以实现app的全屏而又不影响状态栏和导航栏了。如图:

那么,问题来了。加入直接这样设置,手机使用虚拟按键的,像华为各种型号的手机,布局和Navigation Bar会重叠导致冲突,比如这样:

而且,不适配4.4以下的系统。

为了解决问题,查看了很多资料,也自己尝试了一下,发现很多方法都不适合。后来尝试了一下,低于4.4的版本,也就是values下的styles,直接把parent的值,设置成NoTitleBar或者其它的兼容4.4以下版本的Theme(当然,4.4以下的系统,没办法实现沉浸式),然后values-v19和v21的保持TranslucentDecort实现沉浸式。

看了很多网友的资料,有人尝试在layout的总布局里设置android:fitsSystemWindows="true",但这样子Status Bar也就废了,这不是我们想要的。

把values-v19和v21的styles里的

<item name="android:windowTranslucentNavigation">false</item>

设置成false,尝试了一下,成功了。带有虚拟按键的系统,自动把布局顶上去了。

上一篇:Android蓝牙通信编程

栏    目:Android代码

下一篇:Android onCreateOptionsMenu的使用方法总结

本文标题:Android 虚拟按键与沉浸式的适配方法

本文地址:http://www.codeinn.net/misctech/66175.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有