相信如今大部分的人已经了解过 Flutter. 若是尚未,那么能够去 Flutter官网 了解一下安全
如今的手机已经不是方方正正的屏幕了,因此咱们在写一些UI的时候可能会出现以下问题:app
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text(widget.title),
),
body: ListView.builder(itemBuilder: (context, index) {
return SizedBox(
height: 30,
child: Text(
'Data',
style: TextStyle(fontSize: 18),
),
);
}),
floatingActionButton: FloatingActionButton(
onPressed: _incrementCounter,
tooltip: 'Increment',
child: Icon(Icons.add),
),
);
}
复制代码
为了解决这个问题,Flutter 引入了 SafeArea(安全区域),咱们只须要在代码中加入SafeAreaui
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text(widget.title),
),
body: SafeArea( // 加入SafeArea
child: ListView.builder(itemBuilder: (context, index) {
return Padding(
padding: EdgeInsets.only(left: 10, bottom: 18),
child: Text(
'Data',
style: TextStyle(fontSize: 18),
),
);
}),
),
floatingActionButton: FloatingActionButton(
onPressed: _incrementCounter,
tooltip: 'Increment',
child: Icon(Icons.add),
),
);
}
复制代码
能够看到问题已经被解决。spa
咱们还能够仅指定特定的某一位置:debug
SafeArea(
top: false,
bottom: true,
left: true,
right: false,
),
复制代码
咱们点进 SafeArea 的源码查看 build
方法code
Widget build(BuildContext context) {
assert(debugCheckHasMediaQuery(context));
// 这里获取到padding
final EdgeInsets padding = MediaQuery.of(context).padding;
return Padding( // 返回了一个 Padding widget
padding: EdgeInsets.only(
left: math.max(left ? padding.left : 0.0, minimum.left),
top: math.max(top ? padding.top : 0.0, minimum.top),
right: math.max(right ? padding.right : 0.0, minimum.right),
bottom: math.max(bottom ? padding.bottom : 0.0, minimum.bottom),
),
child: MediaQuery.removePadding(
context: context,
removeLeft: left,
removeTop: top,
removeRight: right,
removeBottom: bottom,
child: child,
),
);
}
复制代码
能够看到SafeArea经过MediaQuery来检测屏幕尺寸,使应用程序的大小能与屏幕适配。cdn
而后返回了一个Padding Widget 来包裹住咱们编写的页面。这样咱们的页面就不会被异形屏幕给遮挡住了。blog