Flutter如何获取屏幕的分辨率和实际画布的分辨率

简介: Flutter如何获取屏幕的分辨率和实际画布的分辨率

Flutter如何获取分辨率

在Flutter中,你可以使用MediaQuery来获取屏幕的分辨率和实际画布的分辨率。


要获取屏幕的分辨率,你可以使用MediaQuery.of(context).size属性,它返回一个Size对象,其中包含屏幕的宽度和高度。下面是一个获取屏幕分辨率的例子:


Size screenSize = MediaQuery.of(context).size;
double screenWidth = screenSize.width;
double screenHeight = screenSize.height;

要获取实际画布的分辨率,你可以使用MediaQuery.of(context).devicePixelRatio属性,它返回一个double值,表示实际像素与逻辑像素的比例。通过将屏幕的宽度和高度乘以设备像素比,你可以获得实际画布的分辨率。下面是一个获取实际画布分辨率的例子:


dart


Size screenSize = MediaQuery.of(context).size;
double devicePixelRatio = MediaQuery.of(context).devicePixelRatio;
double canvasWidth = screenSize.width * devicePixelRatio;
double canvasHeight = screenSize.height * devicePixelRatio;

请注意,MediaQuery需要在具有有效BuildContext的上下文中使用,例如在build方法中使用或在initState方法中使用。如果你在build方法之外的地方使用MediaQuery,你需要确保提供一个有效的BuildContext。


需要注意的是,获取的分辨率是逻辑像素分辨率和实际画布分辨率,并不

是指物理设备的硬件分辨率。


    debugPrint('screen size: ${MediaQuery.of(context).size.width},${MediaQuery.of(context).size.height},${MediaQuery.of(context).devicePixelRatio}');

打印结果如下:



2ddd472a89c2c0ae71304b9380e72db0.png

逻辑像素分辨率和实际画布分辨率

逻辑像素分辨率和实际画布分辨率是Flutter中涉及屏幕显示的两个重要概念。


逻辑像素分辨率(

逻辑像素分辨率(Logical Pixel Resolution):逻辑像素分辨率是Flutter应用程序使用的抽象分辨率,它是与设备独立的,并且以逻辑像素为单位进行度量。在逻辑像素分辨率下,屏幕的宽度和高度是以逻辑像素为单位进行测量的,不考虑实际的物理像素密度。


实际画布分辨率

实际画布分辨率(Physical Pixel Resolution):实际画布分辨率是实际物理设备上可用的像素分辨率,它是根据设备的物理像素密度进行测量的。在实际画布分辨率下,屏幕的宽度和高度是以实际物理像素为单位进行测量的。


逻辑像素分辨率和实际画布分辨率之间的关系是通过设备像素比(Device Pixel Ratio)来确定的。设备像素比是逻辑像素与实际物理像素之间的比例关系。例如,如果设备像素比为2.0,则逻辑像素分辨率和实际画布分辨率之间的关系为1个逻辑像素对应2个实际物理像素。


在Flutter中,通过MediaQuery可以获取到逻辑像素分辨率(MediaQuery.of(context).size)和设备像素比(MediaQuery.of(context).devicePixelRatio)。通过将逻辑像素分辨率乘以设备像素比,就可以得到实际画布分辨率。


理解逻辑像素分辨率和实际画布分辨率的概念可以帮助我们在开发Flutter应用程序时正确处理屏幕的尺寸和布局,以便在不同设备上获得一致的显示效果。

2ddd472a89c2c0ae71304b9380e72db0.png


上面的例子中,打印出来的逻辑像素分辨率是1280X720;设备像素比是1.5,那么实际的物理像素分辨率就是12801.5X7201.5 为1920X1080.


相关文章
|
容器
Flutter 解决宽度或高度不足而导致的屏幕溢出显示问题
Flutter 解决宽度或高度不足而导致的屏幕溢出显示问题
1085 1
|
容器
深入理解 Flutter 鸿蒙版的 Stack 布局:适配屏幕与层叠样式布局
Flutter 的 Stack 布局组件允许你将多个子组件层叠在一起,实现复杂的界面效果。本文介绍了 Stack 的基本用法、核心概念(如子组件层叠、Positioned 组件和对齐属性),以及如何使用 MediaQuery 和 LayoutBuilder 实现响应式设计。通过示例展示了照片展示与文字描述、动态调整层叠布局等高级用法,帮助你构建更加精美和实用的 Flutter 应用。
568 2
|
Android开发 iOS开发
Flutter中获取监听屏幕方向、锁定屏幕方向
Flutter中获取监听屏幕方向、锁定屏幕方向
623 2
|
Android开发 iOS开发
Flutter应用开发,系统样式改不了?SystemChrome 状态栏、导航栏、屏幕方向……想改就改
Flutter应用开发,系统样式改不了?SystemChrome 状态栏、导航栏、屏幕方向……想改就改
Flutter 获取屏幕宽高
Flutter 获取屏幕宽高
283 0
|
11月前
flutter开发中Use ‘const’ with the constructor to improve performance. Try adding the ‘const’ keyword to the constructor invocation.报错如何解决-优雅草卓伊凡
flutter开发中Use ‘const’ with the constructor to improve performance. Try adding the ‘const’ keyword to the constructor invocation.报错如何解决-优雅草卓伊凡
212 1
|
10月前
|
前端开发 安全 开发工具
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
694 90
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
|
11月前
|
Dart 前端开发
【05】flutter完成注册页面完善样式bug-增加自定义可复用组件widgets-严格规划文件和目录结构-规范入口文件-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
【05】flutter完成注册页面完善样式bug-增加自定义可复用组件widgets-严格规划文件和目录结构-规范入口文件-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
418 75
【05】flutter完成注册页面完善样式bug-增加自定义可复用组件widgets-严格规划文件和目录结构-规范入口文件-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
|
10月前
|
前端开发 Java Shell
【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
710 20
【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
|
11月前
|
Dart 前端开发 容器
【07】flutter完成主页-完成底部菜单栏并且做自定义组件-完整短视频仿抖音上下滑动页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
【07】flutter完成主页-完成底部菜单栏并且做自定义组件-完整短视频仿抖音上下滑动页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
400 18
【07】flutter完成主页-完成底部菜单栏并且做自定义组件-完整短视频仿抖音上下滑动页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈