美文网首页
屏幕适配(四)——刘海屏适配

屏幕适配(四)——刘海屏适配

作者: 王志强_9380 | 来源:发表于2019-09-26 19:32 被阅读0次
1、判断是否有刘海

通过WindowInsets的getDisplayCutout方法获取到DisplayCutout对象,根据DisplayCutout对象来判断是否有刘海

private static boolean hasDisplayCutout(Window window) {

    DisplayCutout displayCutout;
    View rootView = window.getDecorView();
    WindowInsets insets = rootView.getRootWindowInsets();
    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.P && insets != null){
        displayCutout = insets.getDisplayCutout();
        if (displayCutout != null){
            if (displayCutout.getBoundingRects() != null && displayCutout.getBoundingRects().size() > 0 && displayCutout.getSafeInsetTop() > 0){
                return true;
            }
        }
    }
    return false;
}
2、设置是否让内容区域延伸进刘海

如果是非全屏应用,则不做处理,
如果是全屏应用,则通过设置WindowManager.LayoutParams的layoutDisplayCutoutMode属性为LAYOUT_IN_DISPLAY_CUTOUT_MODE_SHORT_EDGES将内容延生进刘海区

WindowManager.LayoutParams params = window.getAttributes();
/**
 *  * @see #LAYOUT_IN_DISPLAY_CUTOUT_MODE_DEFAULT 全屏模式,内容下移,非全屏不受影响
 *  * @see #LAYOUT_IN_DISPLAY_CUTOUT_MODE_SHORT_EDGES 允许内容去延伸进刘海区
 *  * @see #LAYOUT_IN_DISPLAY_CUTOUT_MODE_NEVER 不允许内容延伸进刘海区
 */
params.layoutInDisplayCutoutMode = WindowManager.LayoutParams.LAYOUT_IN_DISPLAY_CUTOUT_MODE_SHORT_EDGES;
window.setAttributes(params);
3、将状态栏设置为沉浸模式
int flags = View.SYSTEM_UI_FLAG_FULLSCREEN | View.SYSTEM_UI_FLAG_HIDE_NAVIGATION | View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN;
int visibility = window.getDecorView().getSystemUiVisibility();
visibility |= flags; //追加沉浸式设置
window.getDecorView().setSystemUiVisibility(visibility);

我们看一下对比图


刘海屏适配对比图.png

可以看到非全屏的应用,刘海和状态栏一样高,不需要适配
沉静模式下,如果没有适配刘海,上面会有一条大黑边

4、置控件是否避开刘海区域

如果有控件被刘海挡住,则要适当的修改控件的位置,或者直接给container设置一个padding。一般而言,刘海的高度就是状态栏的高度。或者通过displayCutout.getSafeInsetTop()获取高度

public static int heightForDisplayCutout(Context context){
    int resID = context.getResources().getIdentifier("status_bar_height", "dimen", "android");
    if (resID > 0){
        return context.getResources().getDimensionPixelSize(resID);
    }
    return 96;
}

LinearLayout layout = findViewById(R.id.container);
layout.setPadding(layout.getPaddingLeft(), CutoutUtils.heightForDisplayCutout(this), layout.getPaddingRight(), layout.getPaddingBottom());
刘海屏调整遮挡控件.png
5、对于有些第三方厂商,也去找官方文档,进行特殊处理

华为:https://devcenter-test.huawei.com/consumer/cn/devservice/doc/50114
小米:https://dev.mi.com/console/doc/detail?pId=1293
Oppo:https://open.oppomobile.com/service/message/detail?id=61876
Vivo:https://dev.vivo.com.cn/documentCenter/doc/103

相关文章

  • 安卓适配

    ------刘海屏------屏幕适配 | Android 刘海屏适配总结Android刘海屏适配方案Androi...

  • 屏幕适配(四)——刘海屏适配

    1、判断是否有刘海 通过WindowInsets的getDisplayCutout方法获取到DisplayCuto...

  • 屏幕适配-刘海屏适配

    Android官方9.0刘海屏适配策略 1.如果非全屏模式(有状态栏),则app不受刘海屏影响,刘海屏的高度就是状...

  • 屏幕适配【刘海屏适配】

    Android官方9.0刘海屏适配策略 如果非全屏(有状态栏),则app不受刘海屏的影响,刘海屏的高就是状态栏的高...

  • SafeArea widget

    SafeArea widget是适配手机屏幕---刘海屏,底部虚拟按钮等.

  • Android 屏幕适配—刘海屏适配

    1、Google官方适配方案 非全屏模式下,刘海屏的高度等于状态栏的高度,此时我们不需要适配刘海屏, 全屏模式下,...

  • Android 屏幕适配-刘海屏适配

    承接Android 屏幕适配 说明:本文仅为简单总结google官方的刘海平适配方案如需具体机型适配,请自行移步g...

  • 刘海屏的适配

    一、适配策略 非全屏状态下不需要适配刘海屏,刘海只占据 toolbar 的位置。 全屏时需要适配刘海屏 二、使用系...

  • 屏幕适配 | Android 刘海屏适配总结

    一、简介 随着 Apple 发布 iPhone X 之后,各大手机厂商也开始模仿这种刘海屏的设计,而且刘海屏手机的...

  • Android 屏幕适配之bug 刘海屏、水滴屏

    对刘海屏、水滴屏做适配前,先在此给出一个基本概念:何谓刘海屏?何谓水滴屏? 上述两种屏幕都可以统称为刘海屏,不过对...

网友评论

      本文标题:屏幕适配(四)——刘海屏适配

      本文链接:https://www.haomeiwen.com/subject/sjzductx.html