场景
在移动端通过 H5 的 canvas 标签绘制图表的时候,不经过任何处理的图表相比较其他元素看起来会有些模糊。
序
先看下面一组高分屏下的圆,上面是普通 div 元素“绘制”的圆,下面是通过 canvas 绘制的圆。可以看出,下面的圆相比较是模糊的。

为什么会这样?
一台普通屏幕上的像素(逻辑像素),可以当做是正常的像素(css中设置的像素),当画一个100px的元素,他就是一个100px的元素。
但是,在出现了一些高分辨率的屏幕之后,就发生了一些变化。随之也出现了一个属性 devicePixelRatio ,它允许我们去查询设备屏幕的像素比。高分屏下(假设devicePixelRatio为3),在css设置的100px(逻辑像素),实际渲染的是300px的物理像素。
而不管是否为高分屏, canvas 中的单位 1 (逻辑像素),就是 1 物理像素,所以在高分屏下,canvas 绘制的图片看起来就模糊了(可以想象成,一张清晰度正常的普通图片为了布满整个背景被强行放大 n 倍,所以看起来模糊了)。

在高分屏上,未处理的Canvas绘制内容相比其他元素显得模糊。这是因为Canvas的逻辑像素始终为1物理像素,而在高分屏下,1逻辑像素对应多个物理像素。解决方法是根据devicePixelRatio调整Canvas的画布大小,使其为物理像素大小,然后通过CSS设置Canvas元素大小为逻辑像素大小。最后使用CSS的scale进行等比放大,保持内容清晰。通过这种方法,可以实现高分屏下Canvas的高清绘制。
最低0.47元/天 解锁文章
2269

被折叠的 条评论
为什么被折叠?



