专栏首页前端儿Canvas 绘制矩形,圆形,不规则图形(线条),渐变等图像效果

Canvas 绘制矩形,圆形,不规则图形(线条),渐变等图像效果

绘制矩形:

getContext("2d") 对象是内建的 HTML5 对象,拥有多种绘制路径、矩形、圆形、字符以及添加图像的方法。

fillStyle 方法将其染成红色,fillRect 方法规定了形状、位置和尺寸。

 
<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8">
        <style type="text/css">
         #myCanvas{ border: 1px dotted #aaaaaa; padding:10px; }
        </style>
    </head>
    
    <body>
        <canvas id="myCanvas" width="300" height="200"> </canvas>
        <script>
        var c = document.getElementById("myCanvas");
        var cxt=c.getContext("2d");
        cxt.fillStyle="#FF0000";
        cxt.fillRect(10,10,150,100); 
        </script>
    </body>
    
</html>

绘制圆形:

创建圆形路径时需要用到对象的arc方法,方法定义如:XXX.arc(x,y,radius,startAngle,endAngle,anticlockwise)

x为圆形起点的横坐标,y为圆形起点的纵坐标,radius为圆形半径,startAngle为开始角度,endAngle为结束角度,anticlockwise是否按顺时针方向进行绘制。

XXX.beginPath() 创建路径,XXX.closePath() 结束路径,然后XXX.fill() 渲染即可。

<script>
        var c = document.getElementById("myCanvas");
        var cxt=c.getContext("2d");
        cxt.fillStyle="#ff0000";
        cxt.beginPath();
        cxt.arc(50,50,30,0,Math.PI*2,true);
        cxt.closePath();
        cxt.fill();
</script>

绘制线条形:

moveTox,y)指定从何处(x,y)开始,lineTo指定在何处结束,来绘制一条线:

然后 调用stroke()实现绘制。

<script>
        var c = document.getElementById("myCanvas");
        var cxt=c.getContext("2d");
        cxt.moveTo(20,20);
        cxt.lineTo(40,90);
        cxt.lineTo(80,70);
        cxt.lineTo(130,90);
        cxt.stroke();
</script>

绘制渐变效果:

使用您指定的颜色来绘制渐变背景,跟绘制普通矩形差不多,只是fillStyle的值为渐变色了而已。

线性渐变:

方法 createLinearGradient(0,0,150,100); 指定了创建线性渐变色范围

方法 grd.addColorStop(0,"#ff0000");   grd.addColorStop(1,"#00ff00"); 为渐变色指定渐变“开始与结束”

 假如你想实现一个上下的线性渐变的效果,那么你应该在调用createLinearGradient(x0,y0,x1,y1) 创建渐变的时候保证点(x0,y0),点(x1,y1)连成的直线为竖直直线,也就是x0=x1。

当然你也可以实现对角线渐变的效果,只要(x0,y0) (x1,y1)组成一条对角线就可以了。

创建上下渐变和对角线渐变可以这样来:

createLinearGradient(0,0,0,300);    // 创建上下渐变

createLinearGradient(10,10,300,300);    // 创建对角线渐变

<script>
        var c = document.getElementById("myCanvas");
        var cxt=c.getContext("2d");
        var grd = cxt.createLinearGradient(0,0,150,100);
        grd.addColorStop(0,"#ff0000");
        grd.addColorStop(1,"#00ff00");
        cxt.fillStyle = grd;
        cxt.fillRect(0,0,150,70);
</script>

径向渐变:

createRadialGradient(x0,y0,r0,x1,y1,r1)    

创建一个沿两个圆之间的锥面绘制渐变。前三个参数代表一个圆心为(x0,y0)半径为r0的开始圆,后三个参数代表圆心为(x1,y1)半径为r1的结束圆。

比如 var grd = cxt.createRadialGradient(100,100,30,100,100,70)

就创建了一个由圆心(100,100)半径为30的圆 ---》 圆心(100,100)半径为70的圆  的渐变效果。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • JS的toFixed方法设置小数点位数后再进行计算,数据出错问题

    书童小二
  • ES6笔记(4)-- Symbol类型

    类似字符串String的声明方式 var str = 'str'; Symbol的声明方式类似,它调用构造函数Symbol()

    书童小二
  • 花儿朵朵

    春天到了,花儿朵朵盛开,hrdv是一座大花园的主人,在他的花园里种着许多种鲜花,每当这个时候,就会有一大群游客来他的花园欣赏漂亮的花朵,游客们总是会询问,某个时...

    书童小二
  • 谢宝友:深入理解 RCU 之概念

    本文介绍 Linux RCU 的基本概念。这不是一篇单独的文章,这是《谢宝友:深入理解Linux RCU》系列的第 3 篇。

    Linuxer
  • ApplicationContextAware接口和Aware接口

    IT云清
  • 干货 | ES安全searchguard落地实践

    作者简介 江榕,携程信息安全部高级信息安全工程师,目前主要负责公司运维安全日志分析平台搭建、参与日常运维安全事件响应、参与运维安全评审。 1、背景 随着大数据技...

    携程技术
  • 【网易严选】iOS持续集成打包(Jenkins+fastlane+nginx)

    严选iOS客户端的现有打包方式是通过远程连接打包机执行脚本去打包,打完包会输出相应的ipa的二维码,扫一扫二维码可以安装,但是随着测试队伍的壮大,外包同学越来越...

    Albert陈凯
  • 【Go】高效截取字符串的一些思考

    最近我在 Go Forum 中发现了 [SOLVED] String size of 20 character 的问题,“hollowaykeanho” 给出了...

    thinkeridea
  • Dart的语法详解系列篇(二)-- 类与函数八、Dart的类与函数

    上一篇主要讲了数据类型、运算符、流程语句等,由于文字太多,我就把剩下的内容分开写一篇文章。 这一篇我们讲Dart的类与函数,内容较多,希望大家可以耐心看完。我...

    AWeiLoveAndroid
  • Deep Lens为AI云病理平台筹集了320万美元

    Dave Billiter是俄亥俄州人,毕业于俄亥俄州北方大学和哥伦布南方大学,于2004年加入Nationwide儿童医院,领导卫生系统的信息学工作。他监督了...

    AiTechYun

扫码关注云+社区

领取腾讯云代金券