对于Flutter来说,刘海屏主要适配的是上下的边距, 需要把不可点击的区域留出来,同时要把背景颜色和图片放上去。
对于上面的边距, 如果使用 Scaffold , appBar已经自动为我们做好了适配,直接使用就行了。
如果使用的是自定义布局的话, Flutter 提供了媒体查询的接口, 可与获取到上边距和下边距的值
我们只需要在布局Widget的时候, 把这个值计算进去就ok了。
需要注意的是: 上边距在 iPhoneX 上的值是 44, 在其他设备上的值是 20, 是包含了电池条的高度的。 下边距在iPhoneX 上的值是34,在其他设备上的值是 0。
现在Flutter出了一个新的Widget,叫做 SafeArea , 直接在外面包一层这个Widget, 就可以让子Widget 不会被刘海覆盖了。