为什么小程序能适配不同机型?因为微信做了这个

我们都知道,小程序是一个跨系统的平台。这就意味着,小程序会在不同的设备上运行,但不同设备的分辨率会有差异。

在小程序中,如何在分辨率不同的设备上保证视觉元素的正常显示?这就需要名为 rpx 的动态尺寸单位。

本期,知晓程序(微信号 zxcx0101)为大家带来小程序 rpx 单位全解析,希望能够帮助你解决有关 rpx 的一切疑问。

为什么需要动态单位和 rpx?

在显示屏上,每一个画面都是由无数的点阵形成的。这个点阵中,每一个点叫做像素,就是 pixel(缩写为 px)。

上面的那句话,对于很多人来说都是常识。

但是,随着 Retina 屏幕(即「视网膜屏」)的推出和高分屏的普及,1 px 所能代表的实际长度并非是一成不变的

对于跨平台、跨设备的应用来说,单纯使用 px 并不能满足需要。因为,这很难保证小程序的元素,能在不同设备上正常显示——同样 px 尺寸的元素,在高分屏上显示会明显要比在低分屏显得更小。

因此,我们需要一个动态的长度单位。这个单位通过对不同屏幕的分辨率进行调整和适配,保证相同元素在不同屏幕上的展示是正常的。

苹果和 Google 对此都有相应的措施:

  • 由于苹果对高分屏的优化良好,所以在 iOS 上,代码中的 1 px 所代表的实际像素数会根据不同设备动态调整,开发者不需要进行二次换算。
  • 由于 Android 设备碎片化严重,Google 不得不建立了一个新的名叫「density-independent pixel(密度无关像素,缩写为 dp)」的尺寸单位,以适应不同分辨率屏幕的尺寸换算。

微信也为小程序提供了一个动态单位解决方案:它就是 responsive pixel(动态像素),简称 rpx

Pixel 与 rpx、dp 如何换算呢?

了解动态单位是怎么来的以后,我们下一步就该学习如何在 pxrpxdp 之间进行换算了。

动态单位与 px 换算的基本概念是:选择一个分辨率作为基准,在基准分辨率中,一个像素点显示有多长,在其他屏幕上会显示同样长度。

例如,dp 与 px 换算公式是:dp = px * (目标设备 dpi 分辨率 / 160)

但微信小程序的 rpx 换算方式,会与其他动态单位的换算方法有些出入。微信官方提供的换算方式更「傻瓜」一些:rpx = px * (目标设备宽 px 值 / 750)

举个例子:

  • 目标设备的宽度如果是 375px,按照 750rpx 进行换算,则等于 1rpx = 0.5px
  • 目标设备的宽度如果是 1125px,换算后 1rpx = 1.5px

想想是不是有些不太对劲?没错,如果将微信小程序放到平板电脑上运行,屏幕的宽度 px 值有可能会变化(横竖屏、分屏模式等等)。这时候,再以宽度为基准,就会出现元素显示不正确的问题。

从这一点可以看出,微信团队目前并不希望将小程序扩展到手机以外的设备中。因此,开发者暂时可以专注于提高小程序在手机上的体验,无需担心多尺寸屏幕带来的适配问题。

那能不能直接让 rpxdp 进行互换呢?当然不能!

dp 是以屏幕分辨率为基准的动态单位,而 rpx 是以长度为基准的动态单位。就像「米」和「平方厘米」不能互换一样,dprpx 两者也是不能直接进行互换的,除非微信官方将 rpx 设定为分辨率基准而非长度基准。

设计师该怎么做?

由于微信使用了 rpx 动态单位,设计稿的尺寸单位也推荐使用 rpx

那么问题来了,如果要改用 rpx 单位,以什么尺寸的屏幕作为设计稿标准会比较合适呢?

在微信官方的文档中,我们看到这样一句话:

在 iPhone 6 上,屏幕宽度为 375px,共有 750 个物理像素,则 750rpx = 375px = 750 物理像素,1rpx = 0.5px = 1 物理像素。

开发微信小程序时设计师可以用 iPhone 6 作为视觉稿的标准。

也就是说,设计师在设计小程序时,可以这样做:

  • 直接以 iPhone 6 的屏幕尺寸(375×667)用作视觉稿尺寸,1 px = 0.5 rpx;
  • 以 1 px = 1 rpx 的标准,将设计稿尺寸设定为 750×1334。

在将设计稿转交给程序员之前,设计师需要清楚地描述设计稿尺寸和单位换算标准等,以便程序员快速实现界面效果。

如果想让你的小程序,在不同尺寸的机型上都能够完美显示,那就好好消化这篇文章吧。

原文发布于微信公众号 - 知晓程序(zxcx0101)

原文发表时间:2016-12-08

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏一场梦

即使不编程,你也应该学会HTML和CSS的9大理由

1322
来自专栏CDA数据分析师

【图表大师一】如何让Excel图表更具“商务气质”?

如何让Excel图表更具“商务气质”? 文/ExcelPro的图表博客 这是去年底的时候,应《电脑爱好者》杂志约稿写的一篇小文,内容大致是《图表之道》第1章的略...

2598
来自专栏互联网杂技

UX 设计之——商品详情页

现如今,30%的在线购物行为发生在手机端上。 对于在线购物一事,所有用户都期望能够得到快速、流畅的体验。因此,在购物过程的每一个阶段,即使付之最小的努力都有可能...

3046
来自专栏无原型不设计

技巧分享: 如何快速搭建一致统一的设计系统

以下内容由摹客(https://www.mockplus.cn)团队翻译整理,仅供学习交流,摹客设计系统是国内独家设计规范制作平台。

1162
来自专栏梁源的专栏

源氏实验室 - JavaScript权威指南 - 思维导图

1504
来自专栏大数据钻研

11 个 HTML5 动画工具

如今,在Web开发中最为流行的语言就是HTML5了,它帮助开发者将多样化的内容展现给用户。在过去两三年中,我们共同看到了HTML5的发展,它逐渐在网络的世界中积...

4786
来自专栏人称T客

HTML受歧视 软件圈缘何不承认他是开发语言?

HTML 是一种专为网页浏览器设计的标记语言,但它到底算不算是真正的程序语言呢?可能有些人认为不是,但当全球有 11 % 的开发者都以 HTML 做为主要开发工...

3535
来自专栏姬小光

普通程序员如何培养设计感?

你好,我是姬小光。如果你订阅这个号比较早,可能会看过我的《像素眼是怎样炼成的》。那篇文章主要是教你如何“找茬”,即如何发现设计稿或者网页上的不足之处。那么何为不...

1501
来自专栏安恒信息

ios6.1.3和6.1.4完美越狱危机并存 警惕越狱诈骗网站

· 最近,黑客winocm连续向人们公开了ios6.1.3和6.1.4完美越狱的部分证据,以证明自己已能够越狱。给很多苦苦等待越狱的果粉带来了希望。...

2965
来自专栏九彩拼盘的叨叨叨

前端学习

前端主要包括 HTML,CSS,JavaScript。开始的时候,可以看熟悉下基本概念

944

扫码关注云+社区

领取腾讯云代金券