如何制作支持显示屏挖孔的应用程序?- Android Java

4

我有一部有刘海屏的手机。 现在,大多数流行的手机都是有刘海屏的。 但是我注意到一个问题,当我测试一个横屏游戏时,它没有支持/识别手机的刘海屏。 并且它不能完全全屏显示。 https://istack.dev59.com/zSaMo.webp

例如,与星际争霸: https://istack.dev59.com/uwB8c.webp

有没有办法在Android Java应用程序中隐藏/支持/识别刘海屏?

谢谢,并祝您拥有愉快的一天!

1个回答

1
根据官方文档
Android可能不允许内容视图重叠系统栏。要覆盖此行为并强制内容扩展到切口区域,请通过View.setSystemUiVisibility(int)方法将以下任何标志应用于视图可见性:
- SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN - SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION - SYSTEM_UI_FLAG_LAYOUT_STABLE
还要注意,setSystemUiVisibility在API Level 30中已被弃用,可以使用windowInsetsController替代。 编辑:尝试使用所有这些标志:
@Override
public void onWindowFocusChanged(boolean hasFocus) {
    super.onWindowFocusChanged(hasFocus);
    if (hasFocus) {
        //Hide status and navigation bars
        int uiOptions;
        if (Build.VERSION.SDK_INT < 19) {
            uiOptions = View.SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION //Prevent layout resize
                    | View.SYSTEM_UI_FLAG_LAYOUT_STABLE        //when bars are shown
                    | View.SYSTEM_UI_FLAG_FULLSCREEN //Enable full screen
                    | View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN //Hides status bar
                    | View.SYSTEM_UI_FLAG_HIDE_NAVIGATION; //Hides navigation bar
        } else {
            uiOptions = View.SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION //Prevent layout resize
                            | View.SYSTEM_UI_FLAG_LAYOUT_STABLE        //when bars are shown
                            | View.SYSTEM_UI_FLAG_FULLSCREEN //Enable full screen
                            | View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN //Hides status bar
                            | View.SYSTEM_UI_FLAG_HIDE_NAVIGATION //Hides navigation bar
                            | View.SYSTEM_UI_FLAG_IMMERSIVE_STICKY; //Immersive ui experience
        }
        getWindow().getDecorView().setSystemUiVisibility(uiOptions);
    }
}

这些标志肯定会移除状态栏,使内容以全屏显示。
然后尝试通过删除每个标志并查看其对屏幕内容的影响来玩弄此代码。这样,您将实际了解每个标志的使用方法。
最后,请阅读每个标志的javadocs,因为它们提供许多细节,并且几乎可以回答有关每个标志的所有问题。

谢谢回复,但没帮上忙。只有导航栏消失了。 - aarong
请尝试使用"SYSTEM_UI_FLAG_FULLSCREEN"来启用全屏模式,同时结合上述标志。此外,如果您想要更沉浸式的体验,请尝试使用"SYSTEM_UI_FLAG_IMMERSIVE_STICKY"。 - Thanasis M
我编辑了我的回答,提供了使用所有上述标志的代码片段。这段代码经过测试并已经使用了一段时间,在我测试的所有设备上都可以按照你的要求全屏显示内容。 - Thanasis M

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接