当前位置: 首页 > news >正文

无锡梦燕服饰网站谁做的如何注册企业

无锡梦燕服饰网站谁做的,如何注册企业,会展设计是干什么的,微信小程序代码怎么弄文章目录 概念介绍实现方法示例代码 我们在上一章回中介绍了动画相关的内容,本章回中将介绍 如何适配屏幕.闲话休提,让我们一起Talk Flutter吧。 概念介绍 我们平常使用的手机屏幕大小不同,App运行在这些大小不同的屏幕上时效果却相同&…

文章目录

  • 概念介绍
  • 实现方法
  • 示例代码

我们在上一章回中介绍了动画相关的内容,本章回中将介绍 如何适配屏幕.闲话休提,让我们一起Talk Flutter吧。

概念介绍

我们平常使用的手机屏幕大小不同,App运行在这些大小不同的屏幕上时效果却相同,其原因就是App对不同大小的屏幕做了适配。因此我们把程序中对不同屏幕大小做处理的操作叫作适配。

适配是移动开发中必不可少的内容,在Android和IOS原生开发中需要做适配,Flutter做为跨端开发的框架,也需要做适配工作。本章回中将介绍在Flutter开发中如何去适配大小不同的屏幕。

实现方法

适配的核心思想是把相同的尺寸乘以一定的比率,使得该尺寸在不同大小的屏幕上占用的屏幕空间相同,这样给人的感觉就是这个尺寸到不同大小的屏幕上看着都一样。

我们举例子来说明:80dp在480*720大小的屏幕上占用1/6屏幕宽度。在240*320大小的屏幕上如果想占用1/6宽度,那么需要40dp.此时就需要让80dp乘以比率0.5才通满足条件。依次类推,在720*960大小的屏幕上如果想占用1/6宽度就120dp,此时就需要让80乘以比率1.5才能满足条件。

适配的思想介绍完了,那么如何计算不同屏幕的比率呢?常用做法是选一个基准值,屏幕的宽度除以基准值就是比率,在App的UI设计中通常以iPone6的屏幕尺寸为基准,它的屏幕尺寸是一个中间尺寸,有比它小的屏幕也有比它大的屏幕,选用这个尺寸大小可以方便适配其它尺寸的屏幕。

iPhone6实际宽度375 * 667,单位是pt,分辨率:750 * 1334,单位是px。为什么是屏幕宽度呢?因为手机屏幕的宽度比长度小,所以通常以宽度和高度中的最小值来适配。

因此我们可以得到比率公式:屏幕比率=屏幕分辨率宽度/750. 750是iPhone6的屏幕宽度,也可以换成UI设计稿中的尺寸,通常设计稿件中的尺寸都是像素,因此这里使用750为基准值,如果设计
稿不以这个尺寸为基准值,那么把750换成设计稿中的尺寸就可以。

示例代码

///自己设计的屏幕适配类,转换单位为dp
class XScreenUtil {static double baseSize = 0;static double physicalWidth = 0;static double physicalHeight = 0;static double realWidth = 0;static double realHeight = 0;static double dpr = 0;static double statusBarHeight = 0;///计算好的屏幕比率static double fitRatio = 0;///计算好的屏幕比率,单位为像素static double fitRatioPx = 0;///pt类似dp,ios中的屏幕单位point的缩写,px是像素缩小,在设计中使用广泛///baseSize以iPhone6为基准,默认值是750px,375dpstatic void init(BuildContext context,[baseSize=375]) {///获取屏幕物理分辨率,单位是pxphysicalWidth = View.of(context).physicalGeometry.width;physicalHeight = View.of(context).physicalGeometry.height;///获取屏幕物理分辨率,单位是ptrealWidth = MediaQuery.of(context).size.width;realHeight = MediaQuery.of(context).size.height;///屏幕的比率,比如2x,3xdpr = View.of(context).devicePixelRatio;///状态栏的高度,除以dpr才是屏幕中实际的的高度statusBarHeight = MediaQuery.of(context).padding.top / dpr;///屏幕适配时以宽度为单位进行适合,screenutil包中分宽度和高度两种适配方式,w为宽度,h为度,ex200.w,200.h.///实际项目中以宽度和高度中数值比较小的一个进行适配fitRatio = realWidth / baseSize;fitRatioPx = physicalWidth / baseSize * 2; ///iphone6的dp和px转换需要乘以2///iphone6时实际值如下:// fitRatio = realWidth / 375;// fitRatioPx = physicalWidth / 750; ///iphone6的dp和px转换需要乘以2debugPrint('PWidth: $physicalWidth, PHeight: $physicalHeight, RWidth: $realWidth, RHeight: $realHeight dpr: $dpr, top: $statusBarHeight');}///以pt为单位时使用此方法static double setFitRatio(double value) {return value * fitRatio;}///以px为单位时使用此方法static double setFitRatioPx(double value) {return value * fitRatioPx;}
}///使用自己设计的屏幕适配类来适配屏幕
Container(color: Colors.orange,width: XScreenUtil.setFitRatio(200),height: XScreenUtil.setFitRatio(200),child: const  Icon(Icons.pages),
),

上面的示例代码单独封装了一个类,通过类的静态方法可以直接使用屏幕比率,也就是代码中的setFitRatio()方法,代码中使用了MediaQuery类的size属性获取到了屏幕的宽度和长度。这个值会随着屏幕的不同而不同。需要注意的是尺寸的单位不一样,使用的方法也不一样。此外,代码中把基准值当作了类构造函数中的可选参数,如果指定了基准值,那么就使用基准值,反之使用默认值750.

看官们,关于"如何实现屏幕适配"相关的内容就介绍到这里,欢迎大家在评论区交流与讨论!

http://www.yayakq.cn/news/494180/

相关文章:

  • 岳阳设计网站推荐游戏网站开发毕业设计
  • 开发一个网站平台多少钱关键词排名优化易下拉系统
  • 网站建设与推广推荐建设电子商城网站
  • 淘宝网站开发系统网站优化推广价格
  • 网站做选择题怎么快速选择做网站需要ftp
  • 网站设计与制作公司重庆餐饮网站设计
  • 做私活 网站网站建设的客户
  • 网站跳转怎么做开发公司交房前保洁谁承担
  • 4p 4c 4r营销理论区别域名查询seo
  • 在平台企业网站推广怎么做网站报价收费单
  • 做网站小程序挣钱吗怎么做代刷网站长
  • 如何做一家专门卖零食的网站php建站软件
  • 上饶建设局网站模具 东莞网站建设
  • 佛山专业的网站建设公司销售手机网站的后期安排
  • 网站建设 实施计划苏州吴江做网站公司
  • 网站的回到顶部怎么做wordpress支持linux吗
  • 仙居网站设计汽车门户网站 源码
  • 网站301了不知道在哪做的定制手机网站
  • 福州网站建设方案咨询宁波seo深度优化平台有哪些
  • 二维码网站建设源码专业建网站 优帮云
  • 建商城网站的平台nas wordpress备案
  • 临安规划建设局网站载网站源码 怎么下载不了
  • 全网模板建站系统计算机程序网站开发是什么
  • 网站建设岗位廉政风险防控一小时学会网站建设
  • 金融网站排名优化正在建设中的网站可算违规
  • 云服务器建立多个网站公众号微网站开发
  • 网站开发相关知识搜狗网址大全
  • 胡芦娃app软件下载网站怎么做百度搜到的网站免费的
  • 网站八个沈阳住房和城乡建设厅网站
  • 免费移动网站模板泰安市最新招聘信息