欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

刘海屏启动页全屏适配

程序员文章站 2024-03-25 10:06:16
...

一般情况下为了启动app的时候没有白屏现象出现,我们都会在 style 中直接指定一个背景图片,并设置全屏显示,如下所示:

<style name="LaunchTheme" parent="AppTheme">
    <item name="android:windowFullscreen">true</item>
    <item name="android:windowBackground">@drawable/welcome_page</item>
    <item name="android:windowDrawsSystemBarBackgrounds">false</item>
</style>

这样操作在普通屏幕中没有什么问题,但是如果是刘海屏就会在屏幕上方出现一个黑色长条,如图:

刘海屏启动页全屏适配

适配方法:

<style name="LaunchTheme" parent="AppTheme">
    <item name="android:windowFullscreen">true</item>
    <item name="android:windowBackground">@drawable/welcome_page</item>
    <item name="android:windowLayoutInDisplayCutoutMode">shortEdges</item>
    <item name="android:windowDrawsSystemBarBackgrounds">false</item>
</style>

注意:如果不是通过 style 方式适配刘海屏,而是通过代码方式适配,就会出现先黑条再全屏的效果,显然不是我们想要的效果,具体可自行尝试。

代码适配刘海屏方式:

internal fun fitCutoutScreen(activity: Activity) {
    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.P) {
        val lp = activity.window.attributes
        lp.layoutInDisplayCutoutMode = WindowManager.LayoutParams.LAYOUT_IN_DISPLAY_CUTOUT_MODE_SHORT_EDGES
        activity.window.attributes = lp
    }
}