canvas 中 rotate 是怎么旋转的

canvas 中 rotate 是怎么旋转的

月光魔力鸭

2019-12-11 16:45 阅读 686 喜欢 3 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>

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

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

第一步

第二步

第三步

第四步

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

 手绘版本

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


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

灵魂画手

转载请注明出处: https://chrunlee.cn/article/canvas-rotate-position.html


感谢支持!

赞赏支持
提交评论
评论信息 (请文明评论)
暂无评论,快来快来写想法...
推荐
在开发过程中多个页面使用的一个小工具类,简单完善了下,还算不错,给各位提供下小思路。
关于jquery,他的核心特点就是无new构造和链式调用,这里根据网上的资料,自己简单理解下,有助于消化核心代码。
最近做个nodejs的项目,使用了thinkjs 3.0 的框架,编辑器为vs code ,之前用的好好的,每次 . 后都有提示的,可是使用了多模块后发现.. model的提示没有了..
需求如下:有一张大图,需要显示大图中的一小部分,目前能知道的时候小图的宽高和坐标,同时大图有一个旋转角度可以知道,目标就是把小图正确的显示出来。
先记录下,不定哪天就查了..防止找不到或不全
最近一直在想着抓一些网盘数据,进行资料归拢,可是当我真正开始的时候.. 还是遇到了反爬,当然我本身就有心理预期,这是肯定会碰到的,只是没想到会在代理IP上耗费这么久,之前的时候也处理过代理IP ,可是由于一知半解,导致很多配置都不理解,debug全靠猜...
在web开发过程中,现在JSON 已经到了俯拾皆是的地步了,操作JSON对于JS来说非常简单,那么我们对于JSON的转化是如何应对的呢?
今天小程序上传体验版本后莫名无法获取用户数据,但是本地开发环境是正常的,通过开发工具的真机进行测试也正常,但是通过开发工具的预览又不正常,初步来看代码是没有问题的,可能是哪里设置有问题。