canvas 中 rotate 是怎么旋转的

简介: 在今天之前,我对canvas中rotate其实是一脸蒙逼的... 虽然之前有做过图片旋转,但那是在他人的基础上直接修改的,至于为啥会这样..讲真,还真没注意过,但是今天又需要用到这块了,实在搞不定了,找了各种资料,终于明白了.. 坐标系的问题。

在今天之前,我对canvas中rotate其实是一脸蒙逼的... 虽然之前有做过图片旋转,但那是在他人的基础上直接修改的,至于为啥会这样..讲真,还真没注意过,但是今天又需要用到这块了,实在搞不定了,找了各种资料,终于明白了.. 坐标系的问题。

想要对rotate了解的话,那么需要知道几个以下几点:

  • 原始坐标系
  • 旋转方向
  • 旋转后的坐标系
  • 宽高别混

OK,我们来实现一个比较简单的需求,如下:

有一个图片,但是是旋转后的,已经旋转了270度,但是通过canvas加载后,想要正常显示出来。OK,就这么一个需求。

先不哔哔,先上结果,再说为啥

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
    <canvas width="4912" height="3459" id="can"></canvas>
</body>
</html>
<script type="text/javascript">
    var canvas = document.getElementById('can');
    var ctx = canvas.getContext('2d');
    var image = new Image();
    image.src = '1.jpg';
    image.onload = function(){
        var width = this.width;
        var height = this.height;
        console.log(width);
        ctx.rotate(270*Math.PI/180);
        ctx.drawImage(this,-width,0,width,height)
    }
</script>

//至于里面的宽高啥的,慢慢根据动态去实现即可。

这段代码大体实现了个什么事情呢?

image.png

image.png

image.png

image.png

到第四步可能还有有点蒙逼,那么我们形象一点。

image.png

这里面还有个问题.. 我也没理解明白,到底画布跟着转么?
按照查找的资料,canvas有两层,一层是虚拟画布,一层是肉眼可见的画布。(我们可以这么理解)
其中,可见的画布保持不变,虚拟画布进行旋转。


OK,灵魂画手又来了,准备一图击杀。

image.png

相关文章
|
8月前
|
前端开发
canvas绘制圆环
canvas绘制圆环
|
前端开发 关系型数据库 容器
利用Canvas进行绘制XY坐标系
原文:利用Canvas进行绘制XY坐标系 首先来一发图 绘制XY的坐标主要是利用Canvas setLeft和setBottom功能(Canvas内置坐标的功能) 1.首先WPF中的坐标系都是从左到右,从上到下的 即左上角位置(0,0)点,所以XY的Canvas要以(RenderTransf...
1747 0
|
6月前
|
前端开发
已知数组 [{ x, y, radius }, ...], 在canvas中绘制出对应图形
已知数组 [{ x, y, radius }, ...], 在canvas中绘制出对应图形
|
7月前
|
前端开发
canvas图形操作(缩放、旋转、位移)
canvas图形操作(缩放、旋转、位移)
|
8月前
|
存储 前端开发
canvas详解05-变形
canvas详解05-变形
91 2
|
8月前
|
存储 前端开发 索引
canvas详解09-像素操作
canvas详解09-像素操作
140 1
|
8月前
|
前端开发
canvas详解07-裁剪
canvas详解07-裁剪
72 1
|
前端开发
canvas渐变
canvas渐变
128 1
canvas渐变
|
前端开发
canvas绘制五角星
canvas绘制五角星
192 0
|
算法 Java Android开发
常用的像素操作算法:Resize、Flip、Rotate
常用的像素操作算法:Resize、Flip、Rotate
399 0
常用的像素操作算法:Resize、Flip、Rotate