博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
微信小程序开发--从px到rpx:
阅读量:6705 次
发布时间:2019-06-25

本文共 1601 字,大约阅读时间需要 5 分钟。

  hot3.png

开发--从px到rpx:

我一直在想,我是不是有必要再写这一节,还是给大家提供一些阅读链接。

因为关于单位的定义都是比较官方的。没什么好讨论的,我这里做一个汇总和简单的说明吧。

首先本文只以移动设备为例说明。

本文摘要:设计师以iphone6为标准出设计稿的话,1rpx=0.5px=1物理像素。Photoshop里面量出来的尺寸为物理像素点。所以可以直接使用标注尺寸数据。

--------------------------------------看懂本文摘要的话,就不用阅读下面的内容了-------------------------------------

【英寸Inch】英寸表示屏幕斜对角线的长度。如下图所示:

 

【像素Pixel】像素是图像的基本采样单位,它不是一个确定的物理量,因为像素点的物理大小是不确定的。如图:

 

【分辨率】分辨率是屏幕像素的数量,一般用屏幕宽度的像素点乘以屏幕高度的像素点。如描述iphone6的分辨率是750*1334.

分辨率又分为【物理分辨率】和【逻辑分辨率】,值得注意的是实际工作中设计师常常给的是物理分辨率,程序中用到的是逻辑分辨率,但是都称为分辨率,容易混淆。

【物理分辨率】是硬件所支持的分辨率,【逻辑分辨率】是软件可以达到的分辨率。

物理分辨率和逻辑分辨率的商称为【像素倍率dpr】,也就是常说的几倍屏。

如下图中所示,iphone6的分辨率写着375*667,这里指的就是它的逻辑分辨率。我们上面提的750*1334则是它的物理分辨率。

所以iphone6的像素倍率=(750*1334)/(375*667)=2

理解了上述的几个概念,我们就可以接着来看下面的几个单位。

【px】px就是Pixel的缩写,就是指像素。这个作为图片采样的基本单位,没什么需要特别说明的。

【rem】在做移动端适配是最常用的方法就是使用rem作为单位,因为rem是根据html的fontsize去动态计算实际的px的。

所以常常应用这点,做反向使用。即根据屏幕大小动态的设置fontsize.来达到不同的分辨率下有一样的效果。

【rpx】rpx其实是对于rem的一种应用的规定,或者说一种设计的方案,官方上规定屏幕宽度为20rem,规定屏幕宽为750rpx。

所以在微信中1rem=750/20rpx。

但是这不是我们要关注的重点。

在使用rem时,我们常常让设计师根据iphone6的标准出设计稿。因为如果以iphone6为标准,并且在iphone6上将fontsize设置成62.5%。

那么1rem就等于10px,我们只要将设计师标注的尺寸(一般标注的是物理分辨率)除以20就可以得到单位为rem的数值了。

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

css中的px与设备的物理像素并非绝对的一比一关系。

px与物理像素的比例与设备的dpr(像素倍率)有关。

rpx称为相对像素值,rpx与物理像素也并非绝对的一比一关系。

wxss将设备宽定义为750rpx,是以iPhone6的分辨率(750x1334)为基准划分的。

也就是说,在iPhone6上,1rpx=1物理像素=0.5px。

因为设计师标注的尺寸一般是物理分辨率。所以如果以iphone6为标准出设计稿的话,那么我们就可以不需要经过换算直接标准rpx。

这节课的内容就到这里结束了。

感谢您的阅读。

作者:第九程序官方
链接:https://www.jianshu.com/p/e8b66de2b7b5
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

转载于:https://my.oschina.net/huqiji/blog/1818659

你可能感兴趣的文章
SqlServer-函数
查看>>
理解 OpenStack 高可用(HA)(3):Neutron 分布式虚拟路由(Neutron Distributed Virtual Routing)...
查看>>
单片机定时器中断原理
查看>>
编程学习要讲究效率和经验
查看>>
使用Jquery+EasyUI 进行框架项目开发案例讲解之四 组织机构管理源码分享
查看>>
hdu3836联通的强还原性点
查看>>
Grunt 之 使用 JavaScript 语法检查工具 jshint
查看>>
JavaScript目录
查看>>
异常 集中异步处理
查看>>
数据库常用术语
查看>>
maven+springMVC+mybatis+junit详细搭建过程
查看>>
(高级篇 Netty多协议开发和应用)第十章-Http协议开发应用(基于Netty的HttpServer和HttpClient的简单实现)...
查看>>
Xcode7.01相对于底版本的变动小结
查看>>
Content of "Essential Software Test Design"
查看>>
网络工程实训_1路由器介绍
查看>>
Asp.Net 之 调用远程Web_Service
查看>>
HBase入门基础教程之单机模式与伪分布式模式安装(转)
查看>>
iOS开发UI篇—UIWindow简单介绍
查看>>
jquery中怎么删除<ul>中的整个<li>包括节点
查看>>
JQuery中 json 和字符串直接相互转换
查看>>