• 技术文章 >web前端 >H5教程

    canvas渐变色:canvas如何实现渐变色的效果?

    不言不言2018-09-26 14:01:03原创4054
    在我们打开某个网页的时候,可能会看到有的页面中有颜色的渐变,感觉很好看,那么,这种渐变色是如何实现的呢?所谓渐变色其实就是颜色之间的过渡,而html5 Canvas渐变是一种用于填充或描边图形的颜色模式,所以,利用canvas如何实现颜色的渐变?本篇文章就来给大家介绍一下canvas渐变色的实现。

    我们要知道canvas提供了两个对象来创建渐变,渐变可以填充在矩形、文本、线条等。

    canvas渐变可以分为线性渐变和径向渐变:

    canvas创建线性渐变的函数是createLinearGradient(x,y,x1,y1)

    canvas创建径向渐变的函数是createRadialGradient(x,y,r,x1,y1,r1)

    下面我们就来分别看看canvas的线性渐变和径向渐变如何实现颜色的渐变。

    首先来看一下canvas线性渐变:

    线性渐变是以线性的模式来改变颜色,也就是水平,垂直或对角方向。

    我们直接来看canvas线性渐变的例子:

    <!DOCTYPE html>
    <html>
    <head>
        <meta charset="UTF-8">
        <title></title>
    </head>
    <body>
       <canvas id="myCanvas"></canvas>
       <script type="text/javascript">
           var canvas=document.getElementById("myCanvas");
           if(canvas && canvas.getContext){
               var ctx=canvas.getContext("2d");
               var grad=ctx.createLinearGradient(0,0,300,0); //创建一个渐变色线性对象
               grad.addColorStop(0,"yellow");                  //定义渐变色颜色
               grad.addColorStop(1,"green");
               ctx.fillStyle=grad;                         //设置fillStyle为当前的渐变对象
               ctx.fillRect(0,0,300,100);                    //绘制渐变图形
           }
       </script>
    </body>
    </html>

    canvas线性渐变效果如下:

    2345截图20180926111547.png

    说明:上面这个canvas线性渐变的例子实现的是水平方向的渐变,如果想要实现垂直方向的渐变色只需要将参数y和y1设置为不同就可以了,想要实现对角方向的渐变色则需要将水平和垂直方向上的参数都设置为不同。(ps:具体的实现可以自己试试,这里就不多说了)

    看完了线性渐变我们就来看一下canvas径向渐变的实现。

    径向渐变是以圆形模式来改变颜色的,颜色以圆形的中心向外扩散。

    我们也来直接看一个canvas径向渐变的例子

    <!DOCTYPE html>
    <html>
    <head>
        <meta charset="UTF-8">
        <title></title>
    </head>
    <body>
    <canvas id="myCanvas" width="400px" height="300px"></canvas>
    <script type="text/javascript">
        var canvas=document.getElementById("myCanvas");
        if(canvas && canvas.getContext){
            var ctx=canvas.getContext("2d");
            var grad=ctx.createRadialGradient(200,200,50,200,200,200) //创建一个渐变色线性对象
            grad.addColorStop(0,"yellow");                  //定义渐变色颜色
            grad.addColorStop(1,"green");
            ctx.fillStyle=grad;                         //设置fillStyle为当前的渐变对象
            ctx.fillRect(0,0,400,400);                    //绘制渐变图形
        }
    </script>
    </body>
    </html>

    canvas径向渐变的效果如下:

    2345截图20180926112818.png

    需要注意的是:在绘制径向渐变时,可能会因为Canvas的宽度或者高度设置不合适,导致径向渐变显示不完全,需要考虑调整Canvas的尺寸。

    说明:上述canvas径向渐变的代码中其实是两个圆,这两个圆的圆心分别是(x,y)和(x1,y1),半径则就是r和r1;最重要的是这两个圆必须设置不同的半径,形成一个内圆和一个外圆。这样渐变色就从一个圆形辐射到另一个圆形。

    本篇文章到这里全部就结束了,关于canvas的更多内容大家可以参考HTML5开发手册

    以上就是canvas渐变色:canvas如何实现渐变色的效果?的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:canvas 渐变色
    上一篇:如何使用HTML5实现地理位置的获取 下一篇:canvas文字怎么换行?canvas文字换行的方法介绍
    PHP编程就业班

    相关文章推荐

    • HTML5 Canvas:绘制渐变色• 兼容主流浏览器的css渐变色• css渐变色彩 省略标记 嵌入字体 文本阴影的详细介绍• html5 canvas绘制放射性渐变色效果代码实例• html5 Canvas实现画未闭合的路径及渐变色的填充方法• 如何使用CSS实现渐变色动画边框的效果(附代码)

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网