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。

相关推荐
韩仔搭建1 小时前
第二章:安卓端启动流程详解与疑难杂症调试手册
android·ui·娱乐
A-花开堪折1 小时前
Android7 Input(七)App与input系统服务建立连接
android
冰糖葫芦三剑客1 小时前
Android 自定义悬浮拖动吸附按钮
android
吃汉堡吃到饱1 小时前
【Android】从Choreographer到UI渲染(二)
android·ui
微信公众号:AI创造财富2 小时前
显示的图标跟UI界面对应不上。
android·ui
aningxiaoxixi2 小时前
安卓 Audio Stream 类型
android
奔跑吧 android2 小时前
【android bluetooth 协议分析 01】【HCI 层介绍 3】【NUMBER_OF_COMPLETED_PACKETS 事件介绍】
android·bluetooth·hci·bt·gd·aosp13
_龙小鱼_5 小时前
Kotlin扩展简化Android动画开发
android·开发语言·kotlin
奔跑吧 android5 小时前
【android bluetooth 协议分析 01】【HCI 层介绍 6】【WriteLeHostSupport命令介绍】
android·bluetooth·bt·gd·aosp13·writelehostsup·hcicmd
uwvwko5 小时前
ctfshow——web入门254~258
android·前端·web·ctf·反序列化