腾讯ISUX: 浏览器亚像素渲染与小数位的取舍
转载自: 腾讯ISUX (https://isux.tencent.com/card-design-thinking.html)
在响应式项目中,百分比的数值的应用越来越多,比如栅格化布局、背景定位、内边距等。以往对于这种数值,我们大都是直接采用计算器计算出来的数值。但这种数值有时会很长,特别是除不尽的数值如23.33333333%。数据不美观不说,关键对于这种小数位的位数应该如何取舍,一直以来都没有理论依据。
为了解决这个问题,我们需要先了解浏览器是如何处理这些小数位的。对于小数位的处理,不同的浏览器有不同的处理方法,主要有三种:处理成整数、保留4位小数或保留15位小数。现代浏览器基本支持保留小数位的处理。由于显示器是由像素单元组成的,对于小于1像素的部分,是无法像像素级那样精确地处理的,而是采用亚像素渲染的方式进行处理(有兴趣了解亚像素渲染,可查看这篇文章“Subpixel rendering”)。这里我们借用 Alex Kilgour 的实验页面对常用的浏览器进行测试,具体实验页面见“带小数位的百分比、像素测试页面”。
一、测试实验
本次实验主要分为三组:
(一)第一组
第一组是测试页面中的例子1,本组主要测试浏览器对百分比小数位的值是如何处理的,方法是设置两个huge元素的百分比宽度为:
50.4234112897987342876343534543534635653654654645676756756756756756765%、
50.5697612897987865876343534543534635653654654645676756756756756756765%。
然后再重新获取浏览器渲染后的百分比数值。
浏览器对百分比小数位的处理主要是保留2位、4位、13位或15位,为了测试是通过四舍五入还是截断处理,第一个百分比的值在第3位、5位、14位小数位取小于5的值,而第二个则取大于5的值。
(二)第二组
第二组是测试页面中的例子2,本组主要测试当宽度的像素值有小于1像素的值,浏览器是如何处理的。方法是设置三个box元素的宽度值分别为:620.4px、620.5px、620.6px,然后再通过重新获取浏览器渲染的宽度值。
(三)第三组
第三组是测试页面中的例子3~6,本组主要测试设置了百分比宽度的box元素在浏览器渲染后的宽度值都保留了几位小数位。
实验原理
1、设置一个宽为1200px 或 5120px 的container元素
在栅格化布局中,1200px的页面宽度是常见的宽度;而5120px是5K屏下的屏幕宽度,基本算是正常页面的极限宽度了。选取这两个值,可以测试在正常页面宽度与极限页面宽度时,浏览器的处理情况。
2、将子元素box的宽度设置成 50.423411289798736% 或 50.569761289798784%
3、计算container宽度与“原始百分比” 以及 “浏览器处理后的百分比” 各自相乘后的宽度值
4、直接获取浏览器渲染出来后box元素的宽度值
以container宽为1200px、box的百分比宽度为50.423411289798736%为例。
(1)box的原始百分比就是 50.423411289798736%,那么通过这个百分比换算后的像素宽度值就是:1200 * 50.423411289798736% = 605.0809354775848px
(2)在Chrome浏览器中,box的百分比宽度最终会被四舍五入成50.4234%。通过这个百分比换算后的像素宽度值是:1200 * 50.4234% = 605.0808px
(3)而浏览器渲染后宽度是605.078125px。
我们将第一组的渲染结果填入“宽度的百分比保留的小数位”、第三组的渲染结果填入“渲染后的宽度值保留的小数位”,最终可以得出以下测试结果。
浏览器 | 宽度的百分比保留的小数位 | 渲染后的宽度值保留的小数位 |
---|---|---|
IE8 | 截断成 2 位 | 四舍五入成整数 |
IE9 | 截断成 2 位 | 四舍五入成整数 |
IE10 | 截断成 2 位 | 13 |
IE Edge | 截断成 2 位 | 13 |
Chrome 55 | 四舍五入成 4 位 | 6 |
Firefox 50 | 四舍五入成 4 位 | 13 |
Safari 10 | 保留 15 位 | 6 |
QQ浏览器 4.1 | 四舍五入成 4 位 | 6 |
Safari 10(iOS 10) | 保留 15 位 | 6 |
QQ浏览器 7.1(iOS 10) | 保留 15 位 | 6 |
Android浏览器(Android 4.2.2) | 保留 15 位 | 6 |
Chrome 55(Android 4.2.2) | 四舍五入成 4 位 | 6 |
QQ浏览器 7.0(Android 4.2.2) | 四舍五入成 13 位 | 6 |
从测试数据可以看出:
“宽度的百分比保留的小数位”方面,所有浏览器都支持小数位的百分比宽度值,其中最短为2位小数位,最长为15位小数位。其中保留15位小数位的浏览器,在最后一位数字的取舍上有一定的偏差,并不是四舍五入的处理。不过最后一位数值对计算后的宽度值的影响很小,所以可以忽略。
如在Safari 10浏览器中,设置了width: 50.4234112897987342876343534543534635653654654645676756756756756756765%的huge元素,其百分比最后处理成50.423411289798736%。原百分比的15、16位小数是42,但Safari最后处理成6。
“渲染后的宽度值保留的小数位”方面,除了IE8、9外,其他的浏览器都支持保留小数位的宽度值,支持6位或13位小数。与百分比的取舍有点不同的是,亚像素渲染的宽度值的在取舍上存在着一定的偏差,不过偏差基本不大于0.01px。
如在Safari 10浏览器中,设置了50.569761289798784%的box元素,基于container计算的宽度是606.8371354775854px,而实际渲染后的宽度值是606.828125px。
二、百分比位数的取舍
浏览器的渲染情况已经了解了,那小数位的位数上,我们又应该如何取舍呢。在第二组实验中(如下面的图1),我们虽然设置了三个各自相差0.1px的元素,但在亚像素渲染中有所偏差,box2-1与box2-2相差0.109375px,而box2-3与box2-2相差0.09375px。前者的差距仔细看还是能看得出来,但后者的差距小于0.1px肉眼基本看不出来。因此,我们只要控制计算后的误差小于0.1px即可。我们以5K屏的宽度5120作为宽度的极限值。那么可以得出以下结果:
0.1/5120*100 = 0.001953125
从这可以看出,只要保留3位小数,无论第4位以及后面的数值是哪个数,误差范围都不会超过0.1像素。
图1
保留3位小数对于主流的浏览器是足够的,但IE系列只能保留2位小数位。如果舍弃的百分数是0.009999%的话,在极限范围内,其导致的误差将是:
5120*0.009999/100 = 0.5119488
如果在舍弃前宽度是620.8119488,那舍弃后的宽度就是620.3。IE8、IE9对小于1像素的部分是会进行取整处理的,因此舍弃前后的整数值是621和620,那将会出现1像素的误差。对于IE8、IE9,我们无法避免出现1像素的误差,因此我们在设置百分比宽度或背景定位时,需能兼容1像素的误差范围。
三、结论
综合以下情况,我们可以得出以下结论:
1、百分比数值只需保留3位小数即可
2、在兼容IE8、IE9的情况下,无法避免1像素的差距,因此百分比宽度或背景定位时,需能兼容1像素的误差范围。
参考文献
Alex Kilgour: Browser Rounding and Fractional Pixels [EB/OL].http://cruft.io/posts/percentage-calculations-in-ie/,2014-11-25
腾讯ISUX: 浏览器亚像素渲染与小数位的取舍相关推荐
- 移动端 像素渲染流水线与GPU Hack
什么是 像素渲染流水线 web页面你所写的页面代码是如何被转换成屏幕上显示的像素的.这个转换过程可以归纳为这样的一个流水线,包含五个关键步骤: 1.JavaScript:一般来说,我们会使用JavaS ...
- html5 3d场景设计,打造H5里的“3D全景漫游”秘籍 - 腾讯ISUX
原标题:打造H5里的"3D全景漫游"秘籍 - 腾讯ISUX 近来风生水起的VR虚拟现实技术,抽空想起年初完成的"星球计划"项目,总结篇文章与各位分享一下制作基于 ...
- 腾讯ISUX: 面向未来的 CSS Variable (CSS变量)
转载自: 腾讯ISUX (https://isux.tencent.com/card-design-thinking.html) CSS Variable 即CSS变量,聊CSS变量之前,我想先来说说 ...
- 腾讯前端组件android,前端之Android入门(2):程序目录及UI简介 - 腾讯ISUX
在这次的文章中,将会介绍Android程序的目录结构以及UI知识,为下一篇实际例子的编写打下基础.由于文章篇幅有限,所以本着先浅后深的思路,从简单介绍入手,然后在往后实际例子编写中再深入扩展学习各个知 ...
- opencv亚像素边缘精度_opencv 快速亚像素边缘_亚像素边缘定位在光纤中应用
摘要:随着图象识别技术更广泛的应用到生产领域,其和自动控制相结合可以大大提高工业生产效率,减少人工操作带来的种种弊端.由于使用图像采集,计算机分析.处理.控制,光纤熔接机物镜检测精确度大大提高,从而使 ...
- 浏览器是怎样渲染网页的呢?
我在掘金上重新整理了这篇文章----浏览器渲染网页过程 - 掘金,格式更加简介好看一些. 目录 Document Object Model (DOM) CSS Object Model (CSSOM) ...
- H5动效的常见制作手法 - 腾讯ISUX
众所周知,一个元素,动往往比静更吸引眼球: 一套操作界面,合适的动态交互反馈能给用户带来更好的操作体验: 一个H5运营宣传页,炫酷的动画特效定能助力传播和品牌打造. 近两年,小到loading动画,表 ...
- 像素生成器获取位置错误_浏览器,像素和舍入错误
像素生成器获取位置错误 我想我们大多数人已经了解了很长时间,无论是在元素宽度,元素位置还是背景位置中,浏览器在计算百分比时很少见得很对. 实际上,我去年所做的背景调查显示得很清楚. 感谢JQuery专 ...
- 字体: 字体平滑,反锯齿,和次像素渲染(收集)
点阵字库是把每一个汉字都分成16×16或24×24个点,然后用每个点的虚实来表示汉字的轮廓,常用来作为显示字库使用,这类点阵字库汉字最大的缺点是不能放大,一旦放大后就会发现文字边缘的锯齿. 点阵字体也 ...
最新文章
- (详细全面)softmax和log_softmax的联系和区别,NLLLOSS和CrossEntropyLoss的联系和区别
- C#利用Attribute实现简易AOP介绍 (转载)
- smarty模板中类似for的功能实现
- 【NOIP2002】【codevs1098】均分纸牌
- java idea 模块_使用IntelliJ IDEA搭建多maven模块JAVA项目
- 使用VB.net建立excel文件
- python rpc调用_从0到1:全面理解 RPC 远程调用
- bat调用bat注意事项(不带上参数 /b 时 会直接退出)
- 接收机端口电压dBuV如何转化为功率dBmW
- java.util.stream.IntStream
- 一个元素的偏移的方法
- 基于vue实现可拖动弹框
- 2021-05-14
- div是什么意思?HTML和CSS中div标签怎么用
- Appium 测试APK
- 贪心高性能神经网络与AI芯片应用
- 计算机培训word,最新计算机培训word资料.pptx
- 掌握.NET中的日常打印
- ListView 单条item刷新
- 数字地图制作原则细节