Flutter中沉浸式状态栏的设置

Flutter中沉浸式状态栏的设置

沉浸式状态栏是什么?

状态栏是指Android手机顶部显示手机状态信息的位置,Android从4.4版本开始新增了透明状态栏功能,状态栏可以自定义颜色背景,是titleBar能够和状态栏融为一体,增进沉浸感。
在这里插入图片描述
状态栏默认为黑色半透明,设置沉浸式状态栏后,可以与标题栏颜色一致,效果如上图。

如何实现沉浸式状态栏

在flutter项目目录下找到android主入口页面MainActivity.kt或MainActivity.java,判断一下版本号然后将状态栏颜色修改设置成透明,因为他本身是黑色半透明。

MainActivity.kt路径:android\app\src\main\kotlin\com\example\flutter_app\MainActivity.kt

新增以下代码:

import android.os.Build;
import android.os.Bundle;


class MainActivity: FlutterActivity() {
    //设置状态栏沉浸式透明(修改flutter状态栏黑色半透明为全透明)
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState);
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
            window.statusBarColor = 0
        }
    }
}

使用Kotlin语言的MainActivity.kt路径:android\app\src\main\java\com\example\flutter_app\MainActivity.java

新增以下代码以上所示的代码。

可能存在的问题及解决方案

在经过上面的设置之后,可能存在背景颜色为浅色而状态栏也为浅色的情况,这时候状态栏就会看不清楚。可以又以下几种解决方案。

// Created by Qiaozi 20210823
//方案1
import 'package:flutter/services.dart';
void main() {
  runApp(MyApp());
  SystemChrome.setSystemUIOverlayStyle(SystemUiOverlayStyle.dark);//有dark和light两个可选值
}


//方案2
//设置 AppBar brightness 属性值,修改状态栏颜色
appBar: AppBar(
        brightness: Brightness.light,
)
//Brightness.light 黑色
//Brightness.dark 白色


//方案3 
//使用AnnotatedRegion修改状态栏颜色
@override
  Widget build(BuildContext context) {

    return AnnotatedRegion<SystemUiOverlayStyle>(
      value: SystemUiOverlayStyle.light,
      child: Material(child:Scaffold(),),);
  }
//SystemUiOverlayStyle.light 白色
//SystemUiOverlayStyle.dark 黑色
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值