canvas 中 rotate 是怎么旋转的

canvas 中 rotate 是怎么旋转的

月光魔力鸭

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


感谢支持!

赞赏支持
提交评论
评论信息 (请文明评论)
暂无评论,快来快来写想法...
推荐
通过jspdf ,我们可以将页面或图片生成pdf下载下来,如果是一些复杂的页面,我们可以将页面转成图片,然后把图片加入到pdf中,生成并下载。
通过修改数据库编码处理存储emoj表情导致的报错问题。
今天刷codewars的题目的时候碰到一个通过js来实现字符串转base64的题目,base64虽然在js或nodejs中经常用,但是我还真没有仔细去看过原理以及如何实现,这回绕不过去了,赶紧找了找资料看了下。
最近折腾的少了,实在没的写了,大约三四个月没更新了,先水一篇。
当一些业务必须通过横屏来实现,但是又没有原生来做,只能通过h5的时候怎么办?
在我们通过canvs画图的时候经常会用到圆,且需要计算出圆上某点的坐标,由于我数学没学好,总是记不得怎么获取,这里记录下,加深记忆
我们经常会有判断一个数值是素数的需求,那么我们如何来实现呢?
突然来了一个调研任务,想要实现一个类似3D虚拟展厅类似的需求,主要就是放一些学生的作品,然后预览啥的,效果还是要全景的效果。 经过一番调查,最终锁定了以前从未接触过的krpano。