Flutter学习-屏幕适配

本文介绍Flutter中的屏幕适配方法,包括单位使用、设备信息获取、常见适配方案及rpx适配实现。

目前移动端设备非常多,并且不同的设备手机屏幕也不相同。
目前做移动端开发都要针对不同的设备进行一定的匹配,无论是移动原生开发、小程序、H5页面
那么下面我们来学习下,Flutter中如何针对不同的手机屏幕来进行适配

1. Flutter的单位

1.1 Flutter中的单位

在进行Flutter开发时,我们通常不需要传入尺寸的单位,那么Flutter使用的是什么单位呢?

  • Flutter使用的是类似IOS中的点pt,也就是point
  • 所以我们经常说iphone6的尺寸是375x667,但是它的分辨率其实是750x1334
  • 因为iphone6的dpr(devicePixelRatio)是2.0,iPhone6plus的dpr是3.0
    在这里插入图片描述

在Flutter开发中我们使用的是对应的逻辑分辨率

1.2 Flutter的设备信息

获取屏幕上的一些信息,可以通过MediaQuery

//获取媒体查询信息对象
          final mediaQueryData = MediaQuery.of(context);
          //获取屏幕的宽度和高度
          final kScreenWidth = mediaQueryData.size.width;
          final kScreenHeight = mediaQueryData.size.height;
          final phySicalWidth = window.physicalSize.width;
          final phySicalHeight = window.physicalSize.height;

          final dpr = window.devicePixelRatio;

          print("屏幕的宽度===$kScreenWidth, 屏幕的高度===$kScreenHeight");
          print("分辨率: phySicalWidth==$phySicalWidth, phySicalHeight===$phySicalHeight");
          print("dpr=======$dpr");

          // 3.状态栏的高度
          // 有刘海的屏幕:44 没有刘海的屏幕为20
          final statusBarHeight = mediaQueryData.padding.top;
          // 有刘海的屏幕:34 没有刘海的屏幕0
          final bottomHeight = mediaQueryData.
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值