flutter SafeArea和SliverSafeArea,适应特殊屏幕
2024-10-22 08:11:18
现如今的手机已经不能提供给应用程序规整的矩形界面了,一些带圆角或者是刘海屏让应用程序的布局更加复杂,甚至是需要单独适配,这对开发者来来太糟糕了。
因此SafeArea控件应用而生,SafeArea通过MediaQuery
检测屏幕的尺寸使应用程序的大小与屏幕适配。
创建一个铺满全屏的ListView,并显示数据,代码如下:
ListView(
children: List.generate(100, (i) => Text('老孟,一个有态度的程序员')),
)
底部的数据明显被遮挡了,想要解决这个问题只需将ListView包裹在SafeArea中即可,代码如下:
SafeArea(
child: ListView(
children: List.generate(100, (i) => Text('老孟,一个有态度的程序员')),
),
)
我们甚至可以指定显示区域,默认情况下上下左右都是指定区域,如下代码去掉左侧区域:
SafeArea(
left: false,
child: ListView(),
)
SliverSafeArea
SliverSafeArea的功能和SafeArea是一样的,区别就是SliverSafeArea用于Sliver控件,比如下面的用法:
CustomScrollView(
slivers: <Widget>[
SliverGrid(
gridDelegate: SliverGridDelegateWithFixedCrossAxisCount(
crossAxisCount: 3, crossAxisSpacing: 5, mainAxisSpacing: 3),
delegate: SliverChildBuilderDelegate((BuildContext context, int index) {
return Container(
color: Colors.primaries[index % Colors.primaries.length],
);
}, childCount: 20),
)
],
)
在刘海屏上的效果:
顶部有一部分被刘海屏遮挡住了,解决此问题的方法是将SliverGrid包裹在SliverSafeArea中:
CustomScrollView(
slivers: <Widget>[
SliverSafeArea(
sliver: SliverGrid(
gridDelegate: SliverGridDelegateWithFixedCrossAxisCount(
crossAxisCount: 3, crossAxisSpacing: 5, mainAxisSpacing: 3),
delegate: SliverChildBuilderDelegate((BuildContext context, int index) {
return Container(
color: Colors.primaries[index % Colors.primaries.length],
);
}, childCount: 20),
),
)
],
)
最新文章
- Mysql服务启动的时候 如何加载配置文件
- linux内核分析作业3:跟踪分析Linux内核的启动过程
- IOS - 消息推送原理和实现
- boa服务器安装
- Oracle数据迁移至MySQL
- 《嵌入式Linux基础教程》补充阅读建议电子数目下载
- Android安全问题 钓鱼程序
- Sending e-mail with Spring MVC---reference
- CPU再烂,俺也支持虚拟化呀,再附送64位WINDOWS的IIS上配置支持PHP的注意事项
- java日期处理总结(二)
- 14.18.1 The InnoDB Recovery Process InnoDB 恢复进程:
- 201521123053《Java程序设计》第3周学习总结
- Zabbix3.4部署
- VS2015|Visual Studio Enterprise 2015简体中文版(企业版)
- 【转】Mysql索引设计原则
- 基于Github&;Hexo的个人博客搭建过程
- 1.python函数式编程-map函数
- Python 类的多态
- 02 请求库之 requests模块
- cookie 常用的几种方法