用JavaScript绘制一个渐变圆圈对角线


本文摘自PHP中文网,作者藏色散人,侵删。

在之前的文章《js的趣味实现:给你一个戴眼镜的笑脸》中给大家介绍了如何用js画一个戴眼镜的笑脸,还蛮好玩的~感兴趣的朋友可以去看一下哈哈~那么本文继续给大家介绍一个有意思的绘图方法。

今天这篇文章的主题就是“编写一个 JavaScript 程序来绘制下图 [对角线,白到黑的圆圈]。”

299ee045d92af342e48a497c3c3d265.png

可能大家初看标题都不知道要实现啥玩意,现在这张图应该就非常清晰可懂了吧!各位可以自己在本地先尝试下怎么用js来实现这张效果图。

下面是我的实现方法:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

<!DOCTYPE html>

<html lang="en">

<head>

    <meta charset="UTF-8">

    <title></title>

</head>

<body>

<canvas id="myCanvas" width="1500" height="800">

    <p>更新您的浏览器!</p>

</canvas>

<script>

    function draw()

    {

        var ctx = document.getElementById("myCanvas").getContext("2d");

        var counter = 0;

        for (var i=0;i<6;i++)

        {

            for (var j=0;j<6;j++)

            {

                //从白到黑

 ctx.fillStyle = "rgb(" + Math.floor(255-42.5*i) + "," + Math.floor(255-42.5*i) +

 "," + Math.floor(255-42.5*j) + ")";

                ctx.beginPath();

                if (i === counter && j === counter)

                {

                    //创建圈

 ctx.arc(25+j*50,30+i*50,20,0,Math.PI*2,true);

                    ctx.fill();

                    //在圆圈周围创建一个边框,这样白色的会可见

 ctx.stroke();

                }

            }

            counter++;

        }

    }

    draw();

</script>

</body>

</html>

好的,我们直接来运行这段代码,效果如下:

55c39cd40f66871ae0bee1f6dfc9eaa.png

简单介绍下涉及到的方法:

getElementById()方法:可返回对拥有指定 ID 的第一个对象的引用;

getContext()方法:返回一个用于在画布上绘图的环境;

floor()方法:可对一个数进行下舍入;

fill()方法:填充当前的图像(路径),默认颜色是黑色;

fillStyle属性:设置或返回用于填充绘画的颜色、渐变或模式;

beginPath()方法:开始一条路径,或重置当前的路径;

arc()方法:创建弧/曲线(用于创建圆或部分圆);

stroke()方法:会实际地绘制出通过 moveTo() 和 lineTo() 方法定义的路径。默认颜色是黑色。

最后给大家推荐《JavaScript基础教程》~欢迎大家学习~

以上就是用JavaScript绘制一个渐变圆圈对角线的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

javascript怎么替换所有字符串

讲解 js 内存管理机制及验证

js基本数据类型有哪些

javascript怎么将字符串转为数字

angularjs的ng-bind-html指令详解

数组长度用size还是length

javascript dom对象怎么转字符串

jsp和javascript是一个东西吗

怎么解决javascript数字计算丢失精度问题?

你需要知道的关于javascript计时器的所有内容

更多相关阅读请进入《javascript》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...