前言

做移动端h5开发很久了,从开始入行到现在。很多知识和工具都是在用前辈留下的遗产,都没有深入的研究过原因,了解为什么要这么去做。

也许自己也是过了交给自己做什么就做什么的阶段了。在国庆节有一个大块的时间,把最近看到的知识总结一下,也算是对这方面的知识划上一个句号。想想着实把国庆节过成了劳动节,没办法,自己就是这样的一个人,“应该去做的,而且有能力做的,如果不去做,心里面总是不舒服”

这篇文章的内容主要分为两个部分:

  1. 高清屏(Retina)相关概念解析和高清屏(Retina)与前端开发的关系;
  2. 前端开发过程中使用什么手段区分高清屏普通屏幕,并且衍生出的适配方案;

注:本篇文章的所有图片来源于网络,如有侵权请告知。

高清屏(Retina)概念解析和前端开发的关系

1. 高清屏概念解析

高清屏(Retina)概念的兴起主要是从乔帮主发布 Retina 设备开始兴起。主要功能如下:

具备足够高的物理像素密度而使人体肉眼无法分辨其中单独像素点的液晶屏。

特点如下:
1. 一种具备超高像素密度的液晶屏;
2. 同样大小屏幕上显示的像素点由一个变为多个;

看一张乔帮主当年发布 高清屏(Retina)时的一张照片:

由乔帮主背后的那两张图可以发现,高清屏和普通平的主要区别:高清屏(Retina)和普通屏相比,相同区域的物理像素点数,高清屏是普通屏的4倍。

2.物理像素点和css的关系

先来看一张图:

由上面的图我们可以知道,当我们使用css设置了一个区域以后,高清屏含有的像素点数是普通屏的4倍。而css设置的像素值(px)属于普通像素点,或者是标准像素点。

那么我们平时在普通屏幕中正常显示的位图图像放在高清的屏幕上会有什么问题呢?由上面的知识可以知道,普通屏幕的1个CSS像素点对应4个高清屏幕的像素点,1个分成4个,不够分的情况下,颜色会取近似值。所以在高清屏上,在普通屏幕正常显示的图片会变的模糊。

可以看下图来加深理解:

这就是为什么我们现在的设计稿为什么都会设计成2倍稿的原因。为了兼容高清屏幕的图片高清晰显示,我们的裁切图是2倍图,在css中使用的时候会使用css压缩2倍。

比如,我们有一个icon.png的文件,切图大小是 200x200 。而我们使用的时候却是使用css设置其大小为100x100。这样基本上就会保证普通屏和高清屏显示一致。

css压缩真的能保证完全一致么?

看了一些网友的文章。css压缩会使图片边缘的锐度减小。

下面是我做的一个简单的实验,比如说我现在有一个276x90的图标文件。我直接把它设置为一个div的背景,在浏览器中看效果:

代码如下:

<div class="item3"></div>
.item3{height:45px;width:138px;background:url(./4.png) no-repeat center;background-size:100% 100%;
}

在网页中的效果如下图:

我把这张图截取下来放到 PS 中放大,之后的效果如下图,可以明显看到在有颜色的字体边缘的颜色变浅,图像周围的锐度减小。

其实,在我们的开发过程中完全没有必要去在意这里的这个细节问题,图像边缘的锐度也是在 PS 中放大了好多倍以后才看出来的,如果是人的肉眼是根本看不出来的。

2. 高清屏(Retina)和前端开发的关系

由上面的知识可以知道。当我们在高清屏中使用普通图片的时候,相当于图片被放大了一倍(可以这么理解:普通屏幕的1px相当于高清屏的2px)。

因为安卓产品的参差不齐和厂商对屏幕制造标准的标准不一样。这个放大的比例并不是固定的。还好我们有一个叫设备像素比的东西来检测当前屏幕是不是属于高清屏幕。

设备像素比的英文单词为devicePixelRatio。它有一个计算公式如下:

devicePixelRatio=屏幕物理像素/设备独立像素

devicePixelRatio其实就是window对象的一个属性,它被大多数的webkit浏览器所支持。看下图是我在我的MacBook Pro上的Chrome中做的测试。很明显是属于高清屏哈ヾ(=^▽^=)ノ

上面是对设备像素比的东西 做了一个简单的了解,下面就来详细了解下几个比较重要的概念。

设备独立像素(device independent pixels)又叫dip或者是dp。它可以用来辅助区分高清屏幕和非高清屏幕。

我们可以通过两个典型的手机来理解上面的概念。iphone3gs和iphone4的屏幕最大的区别就是前者是普通屏幕而后者是使用了高清的retina屏幕。以下是我查到的一些参数信息:

下面的是iphone3gs屏幕信息:

下面是iphone4s屏幕信息:

在iphone3gs垂直的时候,屏幕的宽度为320物理像素。当我们使用<meta name="viewport" content="width=device-width">的时候,会设置视窗布局宽度为屏幕的宽度320px,于是页面就很自然的覆盖在屏幕上。

所以在iphone3gs上屏幕的物理像素位320像素,独立像素也是320像素。因此window.devicePixelRatio=1

而对于iphone4s来说,当屏幕纵向显示的时候,屏幕的物理像素是640像素,而视区宽度不是640像素而是320像素。

这样在iphone4s上,屏幕的物理像素为640像素,独立像素还是320像素,因此window.devicePixelRatio=2

由上面的举例相信已经对设备的物理像素和独立像素有了一个认识,那么总结如下:

  • 设备的物理像素(也叫设备像素),就是屏幕显示颜色的最小的物理单元,也就是我们经常看到的手机分辨率所描述的数字;
  • 设备独立像素(与密度无关的像素),就是我们手机的实际的视窗口的大小。具体来说可以认为是计算机坐标系统中得一个点,这个点代表一个可以由程序使用的虚拟像素(比如: css像素),然后由相关系统转换为物理像素。

怎么区分高清屏和普通屏幕及其适配方案

通过对于第一部分的了解,我们可能已经知道怎么区分高清屏和普通屏了。网上网友总结的结论如下:

通过计算 devicePixelRatio 的值,是可以区分普通显示屏和高清显示器,当devicePixelRatio值等于1时(也就是最小值),那么它普通显示屏,当devicePixelRatio值大于1(通常是1.5、2.0),那么它就是高清显示屏。

那么这部分,就来简单的了解下我们平时在开发过程中,对于我们使用的图片怎么适配高清屏和普通屏。

原理也很简单,就是根据不同的设备像素比来加载不同的图片:

  1. 针对普通显示屏(devicePixelRatio = 1.0、1.3),加载一张1倍的图片
  2. 针对高清显示屏(devicePixelRatio >= 1.5、2.0、3.0),加载一张2倍大的图片

1.Media Queries的解决方案

根据屏幕的设备像素比来加载不同图片可以使用css 的media queries来解决,当然使用css来解决也是兼容性最好的解决方案(其实意味这我们要切两套图片1倍图和2倍图)。

示例的demo如下:

.css{/* 普通显示屏(设备像素比例小于等于1.3)使用1倍的图 */ background-image: url(img_1x.png);
}
@media only screen and (-webkit-min-device-pixel-ratio:1.5){
.css{/* 高清显示屏(设备像素比例大于等于1.5)使用2倍图  */background-image: url(img_2x.png);}
}

CSS Media Queries的优点

  • 只有对应的目标元素才会下载图片资源
  • 跨浏览器兼容
  • 像素可以精确控制

CSS Media Queries的缺点

  • 单调无味的实现过程,特别是大型项目中
  • 只能通过HTML元素的背景图片来实现,无任何语义化可言

2.JavaScript的解决方案

使用js对“window.devicePixelRatio”进行判断,然后根据对应的值给Retina屏幕选择图像。

$(document).ready(function(){if (window.devicePixelRatio > 1) {var lowresImages = $('img');images.each(function(i) {var lowres = $(this).attr('src');var highres = lowres.replace(".", "@2x.");$(this).attr('src', highres);});}
});

Javascript查询的优点

  • 易于实施
  • 非Retina屏幕不用下载过大的资源
  • 像素精确控制

Javascript查询的缺点

  • Retina屏幕下必须下载标准备和高精密度的两个资源
  • Retina屏幕下图像交互可见
  • 浏览器兼容性不强

3.使用SVG矢量图像

SVG矢量图的优点

  • 一个资源适合所有设备
  • 易于维护
  • 面向未来的:可伸缩向量图形

SVG矢量图的缺点

  • 没有像素那样有精度
  • 由于文件大小,不适合复杂的图形
  • 不支持IE7-8和早期的安卓版本

参考文章:

  • 高清显示屏原理及设计方案
  • 设备像素比devicePixelRatio简单介绍

高清屏概念解析与检测设备像素比的方法相关推荐

  1. 宏定义 是否retina高清屏,判断当前设备

    // 是否高清屏 #define isRetina ([UIScreen instancesRespondToSelector:@selector(currentMode)] ? CGSizeEqua ...

  2. 掌财社:怎么解决Canvas绘图出现模糊问题?在高清屏解决方法解析!

    我们在使用高清屏进行工作或者娱乐的时候都会看起来比较舒适,那么大家知道吗?屏幕的一个物理像素就是css所定义的一个逻辑像素.所以下面我们来介绍有关于"怎么解决Canvas绘图出现模糊问题?& ...

  3. 高清图片在不同移动端设备上的显示效果

    今天看到一道前端面试题,是别人面试自己很喜欢的前端团队时出的题目:一张高清图片,怎么保证其在不同移动端设备上的显示效果? 看到这个问题,我就一脸懵逼,实际上我连移动端那些像素都搞不清楚,这道题给我的话 ...

  4. canvas 实现图片局部模糊_Canvas 在高清屏下绘制图片变模糊的解决方法

    前提条件 假设我们要在 canvas 中绘制一张 300 x 90 的图片,并且要保证它在高清屏中不模糊.那么我们首先要准备一张 600 x 180的图片,处理过高清屏的同学应该会有这方面的经验. 问 ...

  5. 高清屏智能手表PSRAM存储芯片APS6404L-SQR-ZR

    智能穿戴设备发展到今天各种形态,功能配置越来越多,从最初的单一手环步数功能,到后面支付,血氧,心率,运动数据等功能配齐. 高清屏智能手表最为亮点的就是屏幕部门,微曲超大AOLED屏幕,配备了像素的高清 ...

  6. 解决小程序canvas高清屏模糊问题

    原因 因为 canvas 不是矢量图,而是像图片一样属于位图.高 dpi 显示设备意味着每平方英寸有更多的像素,比如说二倍屏,手机就会以2个像素点的宽度来渲染一个像素,该 canvas 在屏幕中相当于 ...

  7. canvas绘图在高清屏显示模糊

    问题:canvas在高清屏显示模糊 前几天在做PDF预览时(使用mozilla的pdf.js),发现PDF文字在canvas中显示非常模糊,在网上搜出来的中文结果都没有这方面相关的,后面用英文搜索到了 ...

  8. 华硕U303LA换屏记--普通屏换成高清屏1920x1080

    因为工作需要,  要经常用到手提电脑, 华硕U303LA原来的屏是普通屏. 长时间看时, 看得我眼晴很不舒服. 普通屏都是偏灰色的. 不适宜长时间观看. 我就在网上对比了几天, 去深圳华强北的笔记本屏 ...

  9. emiya-canvas.js 解决ios下拍照倾斜与canvas高清屏下绘图模糊问题

    场景 解决在移动端拍照,用 canvas 绘图出现图片逆时针旋转 90 度的问题. canvas 在高清屏与retina屏下绘图模糊的问题. 如下图: 就用我老婆来做模特了~ 下图是拍照过后渲染在画布 ...

最新文章

  1. (转)创业的注意事项
  2. php十年磨一剑,十年磨一剑
  3. 台大李宏毅Machine Learning 2017Fall学习笔记 (13)Semi-supervised Learning
  4. 介绍KMP算法思想(例题:ACWING 831 kmp字符串)
  5. Vue 之 下载本地资源文件
  6. HDU 5411 CRB and Puzzle(矩阵快速幂+可达矩阵)
  7. 中央预算单位银行账户管理系统单机版2021--运行环境配置指南
  8. Greenplum5.9.0简单使用
  9. 《蜗居》经典台词100句
  10. 鹅厂、狗厂、猫厂、熊厂、鸟厂、粮厂
  11. 鲁大师12月新机性能/流畅榜:小米系包揽性能榜前三,流畅榜上限再突破!
  12. win7 AnkhSVN 安装报错
  13. 魅族20pro参数配置 魅族20pro值得买吗
  14. 这6款软件,让你的工作效率提升90%!
  15. linux 定位 踩内存_记录一次用户态踩内存问题
  16. dba怎么报考_2019年报考DBA需要什么条件,要求是不是很高?
  17. 启动Tomcat报Artifact is being deployed, please wait问题
  18. python使用while、for及循环嵌套实现直角三角形及正、倒金字塔
  19. 3行代码实现自动刷抖音
  20. ideaiu快速查找xml插件

热门文章

  1. 在Win10下使用LiteIDE对EasyDarwin的Go项目进行编译
  2. 清华最强本科毕业生Top10出炉,「从来没有什么天才学霸」
  3. exfat默认配置大小_U盘exFAT格式分配单元大小选多少合适?
  4. TradeX2-M.dll
  5. 中国一些有代表性的铁路和设施(部分)
  6. msedge新建标签页被联想电脑管家篡改的解决办法
  7. Python新手入门之测试代码
  8. Redox bootloader实现分析
  9. FX3U_定位控制_硬件连接
  10. MySQL 运维和第三方工具