前言:

现在的手机品牌和型号越来越多,导致我们平时写布局的时候会在个不同的移动设备上显示的效果不同,

比如我们的设计稿一个View的大小是300px,如果直接写300px,可能在当前设备显示正常,但到了其他设备可能就会偏小或者偏大,这就需要我们对屏幕进行适配。

安卓原生的话有自己的适配规则,可以根据不同的尺寸建立不同的文件夹,系统会根据当前的设备尺寸取对应的大小的布局。而flutter本身并没有适配规则,而原生的又比较繁琐,这就需要我们自己去对屏幕进行适配。

点击直达github地址
如果有帮助,请给我个star

flutter_ScreenUtil

flutter 屏幕适配方案

github
pub
csdn

最新版请看github文档 ,api有些许改动

使用方法:

安装依赖:

安装之前请查看最新版本

dependencies:flutter:sdk: flutter# 添加依赖flutter_screenutil: ^0.4.2

在每个使用的地方导入包:

import 'package:flutter_screenutil/flutter_screenutil.dart';

初始化设置尺寸

在使用之前请设置好设计稿的宽度和高度,传入设计稿的宽度和高度(单位px)

一定在MaterialApp的home中的页面设置(即入口文件,只需设置一次),以保证在每次使用之前设置好了适配尺寸:

//设置适配尺寸 (填入设计稿中设备的屏幕尺寸) 假如设计稿是按iPhone6的尺寸设计的(iPhone6 750*1334)ScreenUtil.instance = ScreenUtil(width: 750, height: 1334)..init(context);

使用:

适配尺寸:

传入设计稿的px尺寸:

根据屏幕宽度适配 width: ScreenUtil().setWidth(540),

根据屏幕高度适配 height: ScreenUtil().setHeight(200),

注意

高度也根据setWidth来做适配可以保证不变形(当你想要一个正方形的时候)

setHeight方法主要是在高度上进行适配, 在你想控制UI上一屏的高度与实际中显示一样时使用.

例如:

//长方形:
Container(width: ScreenUtil().setWidth(375),height: ScreenUtil().setHeight(200),),//如果你想显示一个正方形:
Container(width: ScreenUtil().setWidth(300),height: ScreenUtil().setWidth(300),),

适配字体:

      ScreenUtil().setSp(28)         //传入字体大小,根据系统的“字体大小”辅助选项来进行缩放ScreenUtil().setSp(28,false)  //传入字体大小,不会根据系统的“字体大小”辅助选项来进行缩放for example:Text('My font size is 28px and will not change with the system.',style: TextStyle(color: Colors.black,fontSize: ScreenUtil().setSp(28, false) )),

其他相关api:

    ScreenUtil.pixelRatio       //设备的像素密度ScreenUtil.screenWidth      //设备宽度ScreenUtil.screenHeight     //设备高度ScreenUtil.bottomBarHeight  //底部安全区距离,适用于全面屏下面有按键的ScreenUtil.statusBarHeight  //状态栏高度 刘海屏会更高  单位pxScreenUtil.textScaleFactory //系统字体缩放比例ScreenUtil().scaleWidth  // 实际宽度的dp与设计稿px的比例ScreenUtil().scaleHeight // 实际高度的dp与设计稿px的比例
//导入
import 'package:flutter_screenutil/flutter_screenutil.dart';...@overrideWidget build(BuildContext context) {//设置适配尺寸 (填入设计稿中设备的屏幕尺寸) 假如设计稿是按iPhone6的尺寸设计的(iPhone6 750*1334)ScreenUtil.instance = ScreenUtil(width: 750, height: 1334)..init(context);print('设备宽度:${ScreenUtil.screenWidth}'); //Device widthprint('设备高度:${ScreenUtil.screenHeight}'); //Device heightprint('设备的像素密度:${ScreenUtil.pixelRatio}'); //Device pixel densityprint('底部安全区距离:${ScreenUtil.bottomBarHeight}'); //Bottom safe zone distance,suitable for buttons with full screenprint('状态栏高度:${ScreenUtil.statusBarHeight}px'); //Status bar height , Notch will be higher Unit pxprint('实际宽度的dp与设计稿px的比例:${ScreenUtil().scaleWidth}');print('实际高度的dp与设计稿px的比例:${ScreenUtil().scaleHeight}');print('宽度和字体相对于设计稿放大的比例:${ScreenUtil().scaleWidth * ScreenUtil.pixelRatio}'); print('高度相对于设计稿放大的比例:${ScreenUtil().scaleHeight * ScreenUtil.pixelRatio}'); print('系统的字体缩放比例:${ScreenUtil.textScaleFactory}');return new Scaffold(appBar: new AppBar(title: new Text(widget.title),),body: new Center(child: Column(crossAxisAlignment: CrossAxisAlignment.center,children: <Widget>[Row(children: <Widget>[Container(width: ScreenUtil().setWidth(375),height: ScreenUtil().setHeight(200),color: Colors.red,child: Text('我的宽度:${ScreenUtil().setWidth(375)}dp',style: TextStyle(color: Colors.white,fontSize: ScreenUtil().setSp(12, false),),),),Container(width: ScreenUtil().setWidth(375),height: ScreenUtil().setHeight(200),color: Colors.blue,child: Text('我的宽度:${ScreenUtil().setWidth(375)}dp',style: TextStyle(color: Colors.white,fontSize: ScreenUtil().setSp(12, false),)),),],),Text('设备宽度:${ScreenUtil.screenWidth}px'),Text('设备高度:${ScreenUtil.screenHeight}px'),Text('设备的像素密度:${ScreenUtil.pixelRatio}'),Text('底部安全区距离:${ScreenUtil.bottomBarHeight}px'),Text('状态栏高度:${ScreenUtil.statusBarHeight}px'),Text('实际高度的dp与设计稿px的比例:${ScreenUtil().scaleHeight}',textAlign: TextAlign.center,),Text('实际高度的dp与设计稿px的比例:${ScreenUtil().scaleHeight}',textAlign: TextAlign.center,),Text('宽度和字体相对于设计稿放大的比例:${ScreenUtil().scaleWidth * ScreenUtil.pixelRatio}',textAlign: TextAlign.center,),Text('高度相对于设计稿放大的比例:${ScreenUtil().scaleHeight * ScreenUtil.pixelRatio}',textAlign: TextAlign.center,),SizedBox(height: ScreenUtil().setHeight(100),),Text('系统的字体缩放比例:${ScreenUtil.textScaleFactory}'),Column(crossAxisAlignment: CrossAxisAlignment.start,children: <Widget>[Text('我的文字大小在设计稿上是14px,不会随着系统的文字缩放比例变化',style: TextStyle(color: Colors.black,fontSize: ScreenUtil().setSp(14, false))),Text('我的文字大小在设计稿上是14px,会随着系统的文字缩放比例变化',style: TextStyle(color: Colors.black, fontSize: ScreenUtil().setSp(14))),],)],),),);}

使用示例:

example demo

效果:

适配原理

说一下适配方案, 比如我们设计师设计的UI是根据Iphone6来做的,我们知道 iPhone6的分辨率是750*1334(px),
又或者是根据hdpi的设备来设计的UI,我们知道hdpi的 Android设备是 (240 dpi),像素密度是1.5,即hdpi设备的分辨率宽度是320px, 总之,无论设计稿的单位是px,或者是dp,我们都能够转换成px.
那么我们如果根据px来适配,ios和 android 就都可以兼容了.

假设,我们的设计稿手机是10801920 px.
设计稿上有一个540
960 的组件, 即宽度和宽度是手机的一半. 如果我们直接写的时候组件的尺寸这么定义,在其他尺寸的设备上未必是一半,或多,或少. 但是我们可以按比例来看,即我们要实现的宽度是实际设备的一半.
那么假设我们设备的宽度是deviceWidth和deviceHeight , 我们要写的组件大小为: 宽:(540/1080)*deviceWidth,高度: (960/1920)*deviceHeight.

通过这个公式我们可以发现,我们要写的组件宽度就是设计稿上的尺寸width*(deviceWdith/原型设备宽度).那么每次我们写ui的时候,只要直接哪来设计稿的尺寸*(deviceWdith/设备原型)宽度即可.

原理就是先获取,实际设备与原型设备的尺寸比例.
首先flutter获取设备的尺寸的代码是:

以下数据为我的手机数据:import 'dart:ui';
//因为window是dart:ui中提供的,所以需要引入这个包.
window.physicalSize  //Size(1080.0, 1794.0)  单位px
width =  window.physicalSize.width  //宽度
height =  window.physicalSize.height  //高度//使用这个方法则无需引入包
MediaQuery.of(context).size   //Size(411.4, 683.4)   单位:dp
widhtDp = MediaQuery.of(context).size.width   //宽度 411.4
heightDp = MediaQuery.of(context).size.height  //高度 683.4

设计稿单位是px,且尺寸为1080*1920 px 时:

scaleWidth = width  / 1080;
scaleHeight = height / 1920;

那么我们要写尺寸为500100控件的宽度就是 500scaleWidth .100*scaleHeigh ,注意这时单位是px,flutter中默认组件尺寸单位都是dp,我们还要进行px->dp的操作.除以像素密度就好了.
flutter获取像素密度的方法:

MediaQuery.of(context).devicePixelRatio
window.physicalSize

上面两种方法得到的是一样的结果,但是window对象来自dart:ui,所以我们引入这个包:

import ‘dart:ui’;

设计稿单位是dp,且尺寸为360*640 dp 时:

scaleWidth = widhtDp / 360;
scaleHeight = heightDp / 640;
那么我们要写尺寸为500*100控件的宽度就是 500*scaleWidth .100*scaleHeigh

flutter 屏幕适配 字体大小适配相关推荐

  1. flutter 屏幕尺寸适配 字体大小适配,android面试常用算法

    width: ScreenUtil().setWidth(375), height: ScreenUtil().setHeight(200), ), 适配字体: ScreenUtil().setSp( ...

  2. native字体尺寸自适应 react_react-native中 屏幕以及字体 大小适配

    import { Platform, Dimensions, PixelRatio } from 'react-native'; // iPhoneX const X_WIDTH = 375; con ...

  3. 多分辨率适配—字体大小适配 sp与dp区别

    字体的缩放参数是可以被调整的,通过手机的系统设置->显示->字体大小你可以设置字体的缩放参数(4.0以上手机才有的),然后有四种选择,小.中.大.超大.对于字体sp的缩放的额外处理设计者大 ...

  4. css webapp手机屏幕适配字体大小

    以下这段代码作用是,设置屏幕最大宽度640px,水平居中,以及不同屏幕下字体大小.可以将此放进common.css中使用: @media only screen and (min-width: 640 ...

  5. iOS字体大小适配的几种方法

    摘要:在iOS开发中,有些公司对字体也有适配要求,为了让字体美观,所以在不同尺寸的屏幕上字体大小也要做到适配. 自己总结了几种方法供大家参考. 方法一:用宏定义适配字体大小(根据屏幕尺寸判断) //宏 ...

  6. iOS字体大小适配机型的几种方法

    在iOS开发中,有些公司对字体也有适配要求,为了让字体美观,所以在不同尺寸的屏幕上字体大小也要做到适配. 自己总结了几种方法供大家参考. 方法一:用宏定义适配字体大小(根据屏幕尺寸判断) //宏定义 ...

  7. android 字体大小属于什么类型,聊聊 Android 中的字体大小适配

    本篇文章已授权微信公众号 guolin_blog(郭霖)独家发布 前言 虽然去年写的一篇文章[一种非常好用的Android屏幕适配]就包含字体大小适配,但那篇文章讲的是根据不同屏幕尺寸来适配字体大小的 ...

  8. Android 中的字体大小适配

    Android系统中可以设置字体大小,对于一些设置了特大号字体的设备,往往会出现布局错乱的情况,对此,需要做相关的字体大小适配.根据聊聊 Android 中的字体大小适配这篇博客提供的方案,进行了一些 ...

  9. css中字体大小适配

    # 字体大小的两种单位 font-size: 16px; // 固定大小,就是16像素 font-size: 1vw; // 相对大小,下面介绍转化方法 结果 先说怎么做适配:只需要将每个关于长宽的参 ...

最新文章

  1. 小机上监控AIX和数据库管理系统的运行情况直到性能优化(SQL语句优化和排除硬件问题)...
  2. iOS进阶之iOS中实例变量与属性的区别(7)
  3. 文巾解题 77. 组合
  4. QT的QRadioTuner类的使用
  5. 深信服上网行为管理开启snmp_编写SHELL脚本在CACTI中来实现监控深信服上网行为管理的CPU和内存使用情况...
  6. Android中文API-ViewStub
  7. lfu算法实现java_LFU五种实现方式,从简单到复杂
  8. Swift中文教程(十四) 初始化
  9. python项目---数据可视化(02)
  10. 超过千字的文章,才统计勤写标兵
  11. vmware安装安卓android详教程,虚拟机安装安卓系统教程
  12. 金融行业认同的七本书
  13. mysql interval啥意思_MySQL interval()函数
  14. DZ先生怪谈国标之云台控制流程
  15. (16)全民小视频引流脚本模块化开发10-发送图片私信By飞云脚本学院
  16. 网络直播电视之寻找直播地址(下)
  17. 1bit和1byte_1字节=8bit bit到底是什么?
  18. 西安交通大学计算机组成实验报告,西安交通大学实验报告
  19. 基于CAN总线步进电机驱动器设计
  20. Protege4之基础知识介绍

热门文章

  1. SVG学习之动态插入图片
  2. 史上最全django安装教程
  3. 为人处世须知~(认真看,保存下来喔)
  4. 【金三银四】软件测试简历项目经验怎么写,没有项目经验?
  5. STM32——灰度PID的使用
  6. linux 如何开启和关闭网口
  7. VBOX修改vhd/vdi存储空间大小
  8. 弘辽科技:拼多多商品市场价格怎么设置?如何经营拼多多?
  9. 学习中的英文单词及其他知识
  10. H3C WA4320无线fit AP瘦模式转fat 胖模式 + 配置wifi上线