canvas性能-drawImage渲染图片
canvas性能-绘制图片
canvas绘制图片
一般我们绘制图片会用到的方法是drawImage和putImageData,还有作为测试环境使用的createPattern
drawImage
描述:
使用方式:
ctx.drawImage(image,sx,sy,swidth,sheight,x,y,width,height)
- image的类型:
- HTMLImageElement:这些图片是由Image()函数构造出来的,或者任何的img元素
- HTMLVideoElement:用一个HTML的video元素作为你的图片源,可以从视频中抓取当前帧作为一个图像
- HTMLCanvasElement:可以使用另一个canvas元素作为你的图片源
- ImageBitmap:这是一个高性能的位图,可以低延迟地绘制,它可以从上述的所有源以及其它几种源中生成
- sx:可选。开始剪切的 x 坐标位置
- sy:可选。开始剪切的 y 坐标位置
- swidth:可选。被剪切图像的宽度
- sheight:可选。被剪切图像的高度
- x:在画布上放置图像的 x 坐标位置
- y:在画布上放置图像的 y 坐标位置
- width:可选。要使用的图像的宽度。(伸展或缩小图像)
- height:可选。要使用的图像的高度。(伸展或缩小图像)
putImageData
描述: Canvas 2D API 将数据从已有的 ImageData 对象绘制到位图的方法。 如果提供了一个绘制过的矩形,则只绘制该矩形的像素。此方法不受画布转换矩阵的影响。
使用方式:
ctx.putImageData(imageData, dx, dy, dirtyX, dirtyY, dirtyWidth, dirtyHeight)
- ImageData:包含像素值的数组对象
- dx:源图像数据在目标画布中的位置偏移量(x 轴方向的偏移量)
- dy:源图像数据在目标画布中的位置偏移量(y 轴方向的偏移量)
- dirtyX:可选 在源图像数据中,矩形区域左上角的位置。默认是整个图像数据的左上角(x 坐标)
- dirtyY:可选 在源图像数据中,矩形区域左上角的位置。默认是整个图像数据的左上角(y 坐标)
- dirtyWidth:可选 在源图像数据中,矩形区域的宽度。默认是图像数据的宽度
- dirtyHeight:可选 在源图像数据中,矩形区域的高度。默认是图像数据的高度。
createPattern
描述:指定的方向内重复指定的元素,元素可以是图片、视频,或者其他 canvas 元素,被重复的元素可用于绘制/填充矩形、圆形或线条等等。
使用方式:
ctx.fillStyle = ctx.createPattern(img,"repeat")
ctx.fill();
测试绘制耗时
测试图片尺寸为(500x500)和(1920x1080)的jpg图片
drawImage
首先测试的是drawImage方法,通过绘制同一张图片不同的资源类型下的耗时
Image类型
- 在空白canvas情况下渲染该图片耗时:0.01ms左右
- 在使用了
createPattern填充了canvas作为背景的情况下渲染该图片耗时:0.01ms左右
ImageBitmap类型
- 在空白canvas情况下渲染该图片耗时:1ms左右,(1920*1080)是1.8ms左右
- 在使用了
createPattern填充了canvas作为背景的情况下渲染该图片耗时:0.01ms左右,(1920*1080)是2ms左右
HTMLCanvasElement类型
- 在空白canvas情况下渲染该图片耗时:0.01ms左右
- 在使用了
createPattern填充了canvas作为背景的情况下渲染该图片耗时:12ms左右,(1920*1080)是14ms左右
putImageData
- 在空白canvas情况下渲染该图片耗时:1ms左右
- 在使用了
createPattern填充了canvas作为背景的情况下渲染该图片耗时:2ms左右
| 渲染图片方式 | 空白canvas下渲染耗时 图片尺寸(500*500) | 使用createPattern铺满下渲染耗时 图片尺寸(500*500) | 空白canvas下渲染耗时 图片尺寸(1920*1080) | 使用createPattern铺满下渲染耗时 图片尺寸(1920*1080) |
|---|---|---|---|---|
| drawImage(Image) | 0.01ms | 0.01ms | 0.01ms | 0.01ms |
| drawImage(ImageBitmap) | 0.01ms | 0.01ms | 0.01ms | 0.01ms |
| drawImage(HTMLCanvasElement) | 0.01ms | 12ms | 0.01ms | 14ms |
| putImageData | 1ms | 2ms | 1.8ms | 3ms |
结论
- 由上面的测试结果可以看出在空白canvas下渲染图片,除了putImageData剩下的性能是一致的即Image = ImageBitmap = HTMLCanvasElement > putImageData。
- 而使用了createPattern平铺作为背景的情况下Image = ImageBitmap > putImageData > HTMLCanvasElement
- 渲染图片尺寸大小一般情况下对drawImage(Image)和drawImage(ImageBitmap)的影响较小,而且性能优越。
- createPattern铺满的情况下drawImage(HTMLCanvasElement)的性能最差和drawImage(Image)能达到3个数量级的差距
- drawImage(HTMLCanvasElement)在空白canvas下性能也很优越
- putImageData的性能处于中等,使用createPattern铺满背景的情况下会有一定影响,不过不是太大
所以可以不使用使用createPattern铺满背景的情况下尽量不要使用,可以使用多层canvas,不必要的层级可以减少重绘。或者将平铺的背景转为Image对象使用。
当然以上的结论为我个人开发时的遇到的问题的总结,如果有误请提出。因为样本数量和图片格式并没有达到太多。
canvas性能-drawImage渲染图片的更多相关文章
- canvas代替img渲染图片
移动端用canvas代替img渲染图片,可以提高性能 var oImg = new Image(); oImg.src = url; oImg.onload = function(){ var cvs ...
- Canvas中 drawImage绘制图片不显示
在学习 html5中的 Canvas.drawImage时写了如下代码: <!doctype html> <html> <head><title>研究& ...
- 软件项目技术点(8)—— canvas调用drawImage绘制图片
AxeSlide软件项目梳理 canvas绘图系列知识点整理 html5中标签canvas,函数drawImage(): 使用drawImage()方法绘制图像.绘图环境提供了该方法的三个不同版本 ...
- Canvas 中drawImage 绘制不出图片
在使用Canvas的drawImage绘制图片时,却发现绘制不出图片,原因是图片是异步加载,图片加载完再绘制. //html <img src="1.png" /> & ...
- 提高HTML5 canvas性能的几种方法
简介 HTML5 canvas 最初起源于苹果(Apple)的一项实验,现在已经成为了web中受到广泛支持的2D快速模式绘图(2Dimmediate mode graphic)的标准.许多开发者现在利 ...
- 小程序Canvas性能优化实战
以下内容转载自totoro的文章<小程序Canvas性能优化实战!> 作者:totoro 链接:https://blog.totoroxiao.com/canvas-perf-mini/ ...
- iOS给图片添加滤镜&使用openGLES动态渲染图片
给图片增加滤镜有这两种方式: CoreImage / openGLES 下面先说明如何使用CoreImage给图片添加滤镜, 主要为以下步骤: #1.导入CIImage格式的原始图片 #2.创建CIF ...
- React Canvas:高性能渲染 React 组
React Canvas 提供了使用 Canvas 渲染移动 Web App 界面的能力,替代传统的 DOM 渲染,具有更接近 Native App 的使用体验.React Canvas 提供了一组标 ...
- Android 性能优化——之图片的优化
Android 性能优化——之图片的优化 在Android性能优化中,我们会发现占内存最大的和对性能影响最大的往往是图片资源,其次是控件资源.相对来说,其他的资源的影响会小一点.这里我就先对图片资源的 ...
随机推荐
- MySQL(二):快速理解MySQL数据库索引
索引 基本概念:索引是在存储引擎层实现的,而不是在服务器层实现的,所以不同存储引擎具有不同的索引类型和实现. 数据结构 Tree 指的是 Balance Tree,也就是平衡树.平衡树是一颗查找树,并 ...
- NuGet 学习笔记(1)--Nuget安装使用
安装NuGet扩展 要使用NuGet首先需要安装它(vs2013NuGet) 1. 点击 工具(Tools)-->扩展管理器(Extensions and Updates)...-->右上 ...
- sqlserver 汉字转全拼函数
create function fn_Getquanpin (@str varchar(100)) returns varchar(8000) as begin declare @re varchar ...
- ProGuard使用文档
介绍 是一个对于Java字节码的免费的压缩器,优化器,混淆器和审核器: l 它检测并删除未使用的类,字段,方法和属性. l 它优化字节码并删除未使用的指令. l 它重命名其余类.字段和方法使用短 ...
- 小白经典CNN论文复现系列(一):LeNet1989
小白的经典CNN复现系列(一):LeNet-1989 之前的浙大AI作业的那个系列,因为后面的NLP的东西我最近大概是不会接触到,所以我们先换一个系列开始更新博客,就是现在这个经典的CNN复现啦(。・ ...
- 冰河又一MySQL力作出版(文末送书)!!
写在前面 继<海量数据处理与大数据技术实战>之后,冰河的又一力作<MySQL技术大全:开发.优化与运维实战>出版,相信这本书对任何想系统学习MySQL的小伙伴来说,都会带来实质 ...
- 史上最全java里面的锁
什么是锁 在计算机科学中,锁(lock)或互斥(mutex)是一种同步机制,用于在有许多执行线程的环境中强制对资源的访问限制.锁旨在强制实施互斥排他.并发控制策略. 锁通常需要硬件支持才能有效实施.这 ...
- 什么是Redis?
Remote Dictionary Server(Redis)是一个开源的使用ANSI C语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value 数据库,并提供多种语言的API.它通常被 ...
- Linux性能优化:CPU性能分析工具--vmstat
Blog:博客园 个人 目录 参数说明 输出信息说明 procs memory swap io system cpu 示例 vmstat是Virtual Meomory Statistics(虚拟内存 ...
- [学习笔记]尝试go-micro开发微服务<第一波>
平时项目都是基于c++,lua,node, 现在打算开始自学开发微服务; 也顺带磨砺下go和docker 前期准备 1. 有golang编程基础 本系列文章是基于有golang编程基础,有过实际开 ...