html5 Canvas实现图片旋转的示例


Posted in HTML / CSS onJanuary 15, 2018

众所周知canvas是位图,你可以在里面渲染你要的东西,不过你只能操作canvas的属性来进行编辑。就是说你并不能操作画进canvas的东西,例如我在canvas里添加一幅画,我现在想将那幅画移动10px,我们并不能直接操作那幅画,因为我们根本获取不到那幅画的任何信息。我们永远只能获取到的是canvas对象。

那问题来了,我要怎么旋转图片

其实canvas是提供了各种各样的接口去控制画布的,旋转有rotate()方法。

其实这里的旋转并不是真的把这个画布旋转了,例如我ctx.rotate(Math.PI/2)旋转90°了。并不是说我们在页面上就会看到canvas旋转了90°。我们可以理解为其实canvas是有两个部分组成的,一个是肉眼看得到的画布,一个是用于操作的虚拟画布,我们所有在虚拟画布上的动作都会映射到真实画布中去。

这样说可能很难理解,下面用图来解释一波。首先介绍一下rotate()方法先,它可以旋转画布,旋转点画布的原点,而画布的原点默认是左上角。

html5 Canvas实现图片旋转的示例

下面在给大家看一下旋转45°所呈现的效果:

html5 Canvas实现图片旋转的示例

在这里我们可以看到我刚刚所说的虚拟的画布旋转45°后再向虚拟的画布内插入图片,然后真实画布所呈现的就是虚拟画布和真实画布相交的部分了。这里可能不太好理解,大家仔细想想。

两张图的代码是这样的:

// 未旋转
var img = document.getElementById('img')
var canvas = document.getElementById('canvas')
var ctx = canvas.getContext("2d")
ctx.drawImage(img, 0, 0)
// 逆时针旋转45°
var img = document.getElementById('img')
var canvas = document.getElementById('canvas')
var ctx = canvas.getContext("2d")
ctx.rotate(-Math.PI / 4);
ctx.drawImage(img, 0, 0)

看到这里我想大家基本知道rotate()的使用方法了。

下面就来说说怎么实现再图片中心旋转

再说之前向给大家了解一下canvas的另外两个方法的用法:

ctx.translate(x, y): 这个方法是可以移动画布原点的方法,参数分别是x,y;

ctx.drawImage(img, x, y):这个方法上面用过了,不过里面是有三个参数的,第一个是要插入的图片dom,后面两个x,y分别为插入图片时对img的位置进行修改。

从图可以看出,要想实现围绕图片中心旋转45°,就得把canvas的原点移动到这张图的中心,再旋转canvas,再就是插入图片时将图片往左上角平移图片自身的一半。

这里分别有三个步骤:

  1. 移动canvas原点
  2. 旋转canvas
  3. 插入图片并移动

html5 Canvas实现图片旋转的示例 

下面把这三个步骤分开看看(图片的宽高为400和300)

移动canvas原点

var img = document.getElementById('img')
var canvas = document.getElementById('canvas')
var ctx = canvas.getContext("2d")
ctx.translate(200, 150)
ctx.drawImage(img, 0, 0)

html5 Canvas实现图片旋转的示例

旋转canvas

var img = document.getElementById('img')
var canvas = document.getElementById('canvas')
var ctx = canvas.getContext("2d")
ctx.translate(200, 150)
ctx.rotate(-Math.PI / 4)
ctx.drawImage(img, 0, 0)

html5 Canvas实现图片旋转的示例

插入图片并移动

var img = document.getElementById('img')
var canvas = document.getElementById('canvas')
var ctx = canvas.getContext("2d")
ctx.translate(200, 150)
ctx.rotate(-Math.PI / 4)
ctx.drawImage(img, -200, -150)

html5 Canvas实现图片旋转的示例

这样就大功告成了

ps:大家再做完一系列动作后一定要将canvas的原点,旋转复原。不然再经过一系列操作后,canvas的设置会乱掉。每操作一次完成后都把设置恢复回原样就好了。

var img = document.getElementById('img')
var canvas = document.getElementById('canvas')
var ctx = canvas.getContext("2d")
ctx.translate(200, 150)         // 1
ctx.rotate(-Math.PI / 4)        // 2
ctx.drawImage(img, -200, -150)
// 恢复设置(恢复的步骤要跟你修改的步骤向反)
ctx.rotate(Math.PI / 4)         // 1
ctx.translate(-200, -150)       // 2
// 之后canvas的原点又回到左上角,旋转角度为0
// 其它操作...

还有一点要注意的,我刚刚示范的是图片相对canvas x轴y轴为0所示范的例子,如果不为0的情况下,只需在移动原点的时候ctx.translate(200+x, 150+y)。这里的200和150是该图片的宽高的一半,x,y就是图片相对canvas的x,y

这篇文章讲的只是在图片中心旋转,之后我会写旋转搭配图片的缩放。有写的不好或错误的地方,望指出

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

HTML / CSS 相关文章推荐
利用CSS3实现毛玻璃效果示例源码
Sep 25 HTML / CSS
css3 border-radius属性详解
Jul 05 HTML / CSS
网页切图的CSS和布局经验与要点
Apr 09 HTML / CSS
利用HTML5+css3+jquery+weui实现仿微信聊天界面功能
Jan 08 HTML / CSS
Canvas 文本转粒子效果的实现代码
Feb 14 HTML / CSS
HTML5 Canvas——用路径描画线条实例介绍
Jun 09 HTML / CSS
html5画布旋转效果示例
Jan 27 HTML / CSS
HTML5的download属性详细介绍和使用实例
Apr 23 HTML / CSS
基于HTML5实现类似微信手机摇一摇功能(计算摇动次数)
Jul 24 HTML / CSS
关于解决iframe标签嵌套问题的解决方法
Mar 04 HTML / CSS
奇妙的 CSS shapes(CSS图形)
Apr 05 HTML / CSS
td 内容自动换行 table表格td设置宽度后文字太多自动换行
Dec 24 HTML / CSS
详解html5页面 rem 布局适配方法
Jan 12 #HTML / CSS
详解html5 canvas 微信海报分享(个人爬坑)
Jan 12 #HTML / CSS
利用三角函数在canvas上画虚线的方法
Jan 11 #HTML / CSS
HTML5 Web缓存和运用程序缓存(cookie,session)
Jan 11 #HTML / CSS
canvas进阶之贝塞尔公式推导与物体跟随复杂曲线的轨迹运动
Jan 10 #HTML / CSS
基于canvas使用贝塞尔曲线平滑拟合折线段的方法
Jan 10 #HTML / CSS
canvas实现高阶贝塞尔曲线(N阶贝塞尔曲线生成器)
Jan 10 #HTML / CSS
You might like
PHP函数常用用法小结
2010/02/08 PHP
php 图片加水印与上传图片加水印php类
2010/05/12 PHP
基于php实现长连接的方法与注意事项的问题
2013/05/10 PHP
php curl基本操作详解
2013/07/23 PHP
php define的第二个参数使用方法
2013/11/04 PHP
Yii入门教程之目录结构、入口文件及路由设置
2014/11/25 PHP
Mootools 1.2教程 定时器和哈希简介
2009/09/15 Javascript
jquery ajax执行后台方法
2010/03/18 Javascript
Javascript排序算法之计数排序的实例
2014/04/05 Javascript
jquery 按键盘上的enter事件
2014/05/11 Javascript
jQuery学习笔记之toArray()
2014/06/09 Javascript
利用jQuery实现漂亮的圆形进度条倒计时插件
2015/09/30 Javascript
解决JavaScript数字精度丢失问题的方法
2015/12/03 Javascript
浅析jQuery移动开发中内联按钮和分组按钮的编写
2015/12/04 Javascript
一个超简单的jQuery回调函数例子(分享)
2016/08/08 Javascript
AngularJS 视图详解及示例代码
2016/08/17 Javascript
jQuery EasyUI 右键菜单--关闭标签/选项卡的简单实例
2016/10/10 Javascript
node.js Sequelize实现单实例字段或批量自增、自减
2016/12/08 Javascript
ES6新增数据结构WeakSet的用法详解
2017/08/07 Javascript
React-Native中props具体使用详解
2017/09/04 Javascript
[01:45:05]VGJ.T vs Newbee Supermajor 败者组 BO3 第二场 6.6
2018/06/07 DOTA
将tensorflow模型打包成PB文件及PB文件读取方式
2020/01/23 Python
python3通过qq邮箱发送邮件以及附件
2020/05/20 Python
Python中zipfile压缩文件模块的基本使用教程
2020/06/14 Python
网站性能延迟加载图像的五种技巧(小结)
2020/08/13 HTML / CSS
个性化皮包、小袋、生活配件:Mon Purse
2019/03/26 全球购物
编程实现去掉XML的重复结点
2014/05/28 面试题
北大青鸟学生求职信
2013/09/24 职场文书
大学生社会实践评语
2014/04/25 职场文书
2015年元旦演讲稿
2014/09/12 职场文书
售后客服个人自我评价
2014/09/14 职场文书
2015年大学班长个人工作总结
2015/04/24 职场文书
项目投资意向书范本
2015/05/09 职场文书
2015年学生管理工作总结
2015/05/26 职场文书
Python 中的Sympy详细使用
2021/08/07 Python
html网页引入svg图片的4种方式
2022/08/05 HTML / CSS