HTML5 Canvas坐标变换(canvas移动坐标空间)

boyanx4个月前技术教程29

我们在使用 Canvas 绘制图形时,可能会想对绘制的图形进行变换,例如让图形旋转90度,或者让图像缩小放大等,这些效果都可以通过 Canvas API 的坐标轴变换处理功能来实现。

图形旋转

如果我们要想将图形进行旋转,例如下面这张图片:


可以通过 rotate() 方法来实现这个效果,rotate() 方法用于旋转当前的绘图,带有一个参数 angle,表示旋转角度。旋转的中心点是坐标的原点,是以顺时针方向进行旋转,如果想要以逆时针方向来旋转,可以将参数设置为负数。

示例:

例如上图的实现代码如下所示:

<!DOCTYPE html>
    <html>
        <head>
            <meta charset="utf-8">
            <title>HTML5学习(9xkd.com)</title>
        </head>
        <body>
            <canvas id="mycanvas" width="250px" height="150px" style="border: 1px solid #000;"></canvas>
            <script>
                var can = document.getElementById("mycanvas");
                var ctx = can.getContext("2d");
                ctx.fillStyle = "pink";  // 填充颜色
                ctx.rotate(20*Math.PI/180);
                ctx.fillRect(50, 30, 100, 50);
            </script>
        </body>
    </html>    

图形缩放

图形缩放可以使用 scale() 方法来实现,可以对图形进行放大或缩小设置。注意,这个函数有两个参数,第一个参数为水平方向的缩放倍数,第二个参数为垂直方向的缩放倍数。要将图形缩小,可以将参数值设置为0到1之间的小数,例如 0.5 表示将图形缩小一倍。或者也可以将参数值设置为百分数,例如 0.5=50%、1 = 100%、2=200% 等。

示例:

将图形放大一倍:

<!DOCTYPE html>
    <html>
        <head>
            <meta charset="utf-8">
            <title>HTML5学习(9xkd.com)</title>
        </head>
        <body>
            <canvas id="mycanvas" width="250px" height="150px" style="border: 1px solid #000;"></canvas>
            <script>
                var can = document.getElementById("mycanvas");
                var ctx = can.getContext("2d");
                ctx.fillStyle = "pink";  // 填充颜色
                ctx.fillRect(50, 30, 100, 50);
                ctx.scale(1.5, 1.5);
                ctx.fillRect(50, 30, 100, 50);
            </script>
        </body>
    </html>    

在浏览器中的预览效果:


图形平移

移动图形可以通过 translate() 方法来实现,这个方法中的第一个参数表示将坐标轴向右边移动若干个单位,第二个参数表示将坐标轴圆点向下移动若干个单位。

示例:

将图形水平移动50px,向下移动50px:

<!DOCTYPE html>
    <html>
        <head>
            <meta charset="utf-8">
            <title>HTML5学习(9xkd.com)</title>
        </head>
        <body>
            <canvas id="mycanvas" width="250px" height="150px" style="border: 1px solid #000;"></canvas>
            <script>
                var can = document.getElementById("mycanvas");
                var ctx = can.getContext("2d");
                ctx.fillStyle = "pink";  // 填充颜色
                ctx.fillRect(50, 30, 100, 50);
                ctx.translate(50, 50);
                ctx.fillRect(50, 30, 100, 50);
            </script>
        </body>
    </html>    

在浏览器中的预览效果:


小练习

我们通过上述学习的三个方法,来实现下图所示效果:


实现代码如下所示:

<!DOCTYPE html>
    <html>
        <head>
            <meta charset="utf-8">
            <title>HTML5学习(9xkd.com)</title>
            <script>
                window.onload = function() {
                
                var can = document.getElementById("mycanvas");
                var ctx = can.getContext("2d");

                ctx.translate(200, 10); 
                ctx.fillStyle = "rgba(219,112,147, 0.7)"; 
                for(var i = 0; i < 50; i++){ 
                    ctx.translate(27, 27); 
                    ctx.scale(0.95, 0.95); 
                    ctx.rotate(Math.PI / 10); 
                    ctx.fillRect(0, 0, 90, 50); 
                }
            }     
            </script>
        </head>
        <body>
            <canvas id="mycanvas" width="400" height="300" style="border: 1px solid #000;"></canvas>

        </body>
    </html>    

总结

我们在绘制图形的时候,经常会用到上述几个方法来进行图形变化,需要注意的是,这个变化的不是画布,而是画布上的画进行变化。

查看更多可以点击链接:https://www.9xkd.com/

标签: html转canvas

相关文章

前端【Canvas】基础教程示例集锦(前端开发canvas)

Canvas是HTML5中新增的元素,它是一个可以使用JavaScript绘制图像的区域。Canvas可以用来绘制简单的图形、动画、游戏、数据可视化等等。它是一个非常强大的工具,可以让我们在网页中展示...

Canvas 从入门到劝朋友放弃(图解版)

本文简介点赞 + 关注 + 收藏 = 学会了在前端领域,如果只是懂 Vue 或者 React ,未来在职场的竞争力可能会比较弱。根据我多年在家待业经验来看,前端未来在 数据可视化 和 AI 这两个领域...

解决ios15系统的手机使用html2canvas截图页面空白崩溃

最近ios15系统推出了,公司的app开始测试ios15的兼容,然后就出现了有截图的页面卡顿白屏的问题。业务场景是这样,我们的每个页面都会有多个截图,截图使用的方式是html2canvas这个插件,1...

canvas学习和面向对象(二)(canvas 教程)

Canvas 学习(二)上一篇Canvas 学习(一)中我是用canvas绘制了一些基本和组合的图形.现在开始绘制图片和动画帧,以及面向对象的升级版本.还是一样,看代码,所有的代码都托管在github...

电子病历编辑器开发之路:Canvas vs DOM 的深度剖析与技术抉择

在医疗信息化飞速发展的今天,电子病历(EMR)编辑器作为医疗系统的核心组件,其性能与功能的优劣直接关乎医疗工作的效率与数据安全。近期,我在研读一篇关于 EMR 电子病历编辑器推广的文章时,其中对基于...

HTML5教程关于canvas的线条知识,可以这样总结方法

本文为兄弟连云课堂《HTML5教程canvas学习:线条知识总结》学习笔记 订阅走一波。前言初次学习HTML5绘图canvas线条部分内容,特写下本篇博文总结,以供今后可以复习使用。在本篇博文中,主要...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。