Android全屏黑边解决方案

在Android12以上的手机,设置全屏后屏幕底部有黑边或者白边,有的屏幕顶部有黑边。解决方案很简单,在使用的主题中添加对应的设置即可,如下:

  1. res/values/themes.xml

    xml 复制代码
    <resources>
        <style name="Base.Theme.Laughf" parent="Theme.Material3.DayNight.NoActionBar">
            <!--全屏后顶部状态栏将不显示-->
            <item name="android:windowFullscreen">true</item>
    
            <!--使屏幕顶部的状态栏透明-->
            <item name="android:windowTranslucentStatus">true</item>
    
            <!--使屏幕底部的导航栏透明,有的手机是半透明-->
            <item name="android:windowTranslucentNavigation">true</item>	        
        </style>
    
        <style name="Theme.Laughf" parent="Base.Theme.Laughf" />
    </resources>
  2. res/values-v27/themes.xml

    xml 复制代码
    <?xml version="1.0" encoding="utf-8"?>
    <resources>
        <style name="Base.Theme.Laughf" parent="Theme.Material3.DayNight.NoActionBar">
            <!--全屏后顶部状态栏将不显示-->
            <item name="android:windowFullscreen">true</item>
    
            <!--使屏幕顶部的状态栏透明-->
            <item name="android:windowTranslucentStatus">true</item>
    
            <!--使屏幕底部的导航栏透明,有的手机是半透明-->
            <item name="android:windowTranslucentNavigation">true</item>
    
            <!--在我的小米11pro(android13) 上,虽然状态栏隐藏了,但是原状态位置上会被显示黑色。用下面的属性可解决,但是它是在API27才出的,所以需要声明在v27的文件夹中-->
            <item name="android:windowLayoutInDisplayCutoutMode">shortEdges</item>
        </style>
    </resources>
  3. 使用主题

    xml 复制代码
    <?xml version="1.0" encoding="utf-8"?>
    <manifest xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:tools="http://schemas.android.com/tools">
    
        <application
            android:icon="@mipmap/ic_launcher"
            android:label="@string/app_name"        
            android:theme="@style/Theme.Laughf">
            <activity
                android:name=".MainActivity"
                android:exported="true">
                <intent-filter>
                    <action android:name="android.intent.action.MAIN" />
                    <category android:name="android.intent.category.LAUNCHER" />
                </intent-filter>
            </activity>
        </application>
    
    </manifest>

    这里把主题应用到了application,则所有的界面都会全屏,也可单独把主题设置到需要全屏的Activity上。

这种全屏后有个问题,如果在界面的底部有按钮,且系统启用了虚拟导航栏,则我们界面的按钮可能显示在虚拟导航栏的下方,这样导致点击不了下面的按钮。这种情况可以看看怎么获取虚拟导航栏的高度,然后给界面设置一个marginBottom。

相关推荐
杉氧17 小时前
深入理解 Compose 重组机制:快照系统如何驱动 UI 精准刷新?
android·架构·android jetpack
召钱熏17 小时前
状态枚举正确≠渲染正确:一个语音按钮的状态机边界修复实录
android·前端
杉氧18 小时前
深度解析:Jetpack Compose 核心架构与底层原理 —— 十年安卓老兵的“破茧重生”
android·架构·android jetpack
通玄18 小时前
Jetpack Compose 入门系列(七):ViewModel 与界面状态管理
android
落魄Android在线炒饭18 小时前
Android Framework 开发技巧:android.jar 生成与系统快速编译验证
android
如此风景19 小时前
Kotlin Flow操作符学习
android·kotlin
plainGeekDev20 小时前
GreenDAO → Room
android·java·kotlin
weiggle20 小时前
第八篇:ViewModel + Compose——生产级状态管理实践
android
恋猫de小郭1 天前
Amper 正式转正 Kotlin Toolchain ,Gradle 未来何去何从
android·前端·flutter
plainGeekDev1 天前
ButterKnife → ViewBinding
android·java·kotlin