使用canvas来完成线性渐变和径向渐变的功能的方法示例


Posted in HTML / CSS onJuly 25, 2019

fillStyle的第二种使用情况就是渐变色的填充。渐变色就分为线性渐变色和径向渐变色。

线性渐变:大致分为两步 这里又会使用到canvas的两个新的函数。

第一步 : 使用一个新的函数createLinearGradient( xstart,ystart,xend,yend );var linearGrad = context.createLinearGradient(xstart,ystart,xend,yend);

他有四个参数。分别为,xstart,ystart,xend,yend他们构成两个坐标,这两个坐标构成一个线段。这个线段实际上就是一个渐变线。渐变线用于定义渐变的方向和尺度。

第二步 : 就是在这个渐变线的基础上添加colorStop,这个方法叫addColorStop(stop,color)。他有两个参数分别为stop,color。第一个参数是一个浮点值用来决定关键色的位置。第二个参数是用来决定关键色的颜色。linearGrad.addColorStop(stop,color);

当做完这两步后这个linearGrad变量就可以作为fillStyle传入这个属性中。

看代码:

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>线性渐变</title>
</head>

<body>
    <canvas id="canvas" style="border: 1px solid #aaa;display:block;margin:0 auto"></canvas>
</body>

</html>
<script>
    window.onload = function () {
        var canvas = document.getElementById("canvas");

        canvas.width = 800;
        canvas.height = 600;

        if (canvas.getContext("2d")) {
            var context = canvas.getContext("2d");  //获取上下文绘图环境

            var linearGrad = context.createLinearGradient(0, 0, 800, 600);   //渐变线的起始坐标为(0,0)终止坐标为(800,600)

            linearGrad.addColorStop(0.0, '#000');    //第一个参数表示关键颜色的位置0表示起始位置,1表示终点位置,第二个参数表示关键颜色的颜色。
            linearGrad.addColorStop(1.0, '#fff');


            context.fillStyle = linearGrad;
            context.fillRect(0, 0, 800, 600);

        } else {
            alert('您的浏览器不支持canvas,请更换浏览器尝试~')
        }
    }
</script>

效果图:

使用canvas来完成线性渐变和径向渐变的功能的方法示例

当我们创建好linearGrad这个变量后,我们是可以addColorStop是可以添加很多个的。

举个例子:

代码:

var linearGrad = context.createLinearGradient(0, 0, 800, 600);   //渐变线的起始坐标为(0,0)终止坐标为(800,600)
 linearGrad.addColorStop(0.0, '#fff');
 linearGrad.addColorStop(0.25, '#FB3');
 linearGrad.addColorStop(0.5, '#690');
 linearGrad.addColorStop(0.75, '#09C');
 linearGrad.addColorStop(1.0, '#000');

效果图:

使用canvas来完成线性渐变和径向渐变的功能的方法示例

还有我们定义的渐变线是倾斜的,我们也可以定义成水平的或者垂直的。我们只要修改一下渐变线的终止坐标即可。看代码,做成水平的渐变色:

var linearGrad = context.createLinearGradient(0, 0, 800, 0);

效果图:

使用canvas来完成线性渐变和径向渐变的功能的方法示例

垂直的渐变色:

var linearGrad = context.createLinearGradient(0, 0, 800, 0);

效果图:

使用canvas来完成线性渐变和径向渐变的功能的方法示例

我们所做的不管倾斜的水平的还是垂直的,都是贯穿了整个画布,那如果我们的渐变线只指定到了画布的一部分会是什么效果呢?我们修改一下

var linearGrad = context.createLinearGradient(0, 0, 400, 300);

效果图:

使用canvas来完成线性渐变和径向渐变的功能的方法示例

同理我们所创建的渐变线也可以超过这个画布的最大宽高。我们修改一下

 

var linearGrad = context.createLinearGradient(-200, -100, 1000, 800);

效果图:

使用canvas来完成线性渐变和径向渐变的功能的方法示例

还有我们所绘制的填充的形状也不一定占满整个画布的。我们可以任意调整自己定义的形状。这个填充的形状会在我们定义的渐变线上找到合适的填充色进而填充出来。举个例子:

var linearGrad = context.createLinearGradient(-200, -100, 1000, 800);

效果图:

使用canvas来完成线性渐变和径向渐变的功能的方法示例

径向渐变:与线性渐变的区别是,径向渐变定义的是一个放射状的渐变。而这个放射状的渐变是定义在两个同心圆的基础上。而不像线性渐变是定义在两点之间的。

径向渐变也是需要两步来完成。

第一步 : 使用一个新的函数createRadialGradient(x0,y0,r0,x1,y1,r1); 他有6个参数。前三个参数定义第一个圆环的坐标和半径,后三个参数定义第二个圆环的坐标和半径。整个径向渐变就发生在这两个圆之间。var radialGrad = context.createRadialGradient(x0,y0,r0,x1,y1,r1);

第二步 : 和线性渐变是一样的,就不过多介绍。radialGrad.addColorStop(stop,color);

代码和线性渐变的代码十分类似。只不过这里使用的是createRadialGradient,我们给他传入参数createRadialGradient(300,300,0,300,300,500),前三个参数定义的是在画布中心,半径为0的一个点。后三个参数定义的是在画布中心半径为500的一个大圆。这样就定义了一个从一个点向外辐射的一个径向渐变。看一下代码

 

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>径向渐变</title>
</head>

<body>
    <canvas id="canvas" style="border: 1px solid #aaa;display:block;margin:0 auto"></canvas>
</body>

</html>
<script>
    window.onload = function () {
        var canvas = document.getElementById("canvas");

        canvas.width = 600;
        canvas.height = 600;

        if (canvas.getContext("2d")) {
            var context = canvas.getContext("2d");

            var radialGrad = context.createRadialGradient(300, 300, 0, 300, 300, 500);

            radialGrad.addColorStop(0.0, '#fff');
            radialGrad.addColorStop(0.25, '#FB3');
            radialGrad.addColorStop(0.5, '#690');
            radialGrad.addColorStop(0.75, '#09C');
            radialGrad.addColorStop(1.0, '#000');

            context.fillStyle = radialGrad;
            context.fillRect(0, 0, 600, 600);

        } else {
            alert('您的浏览器不支持canvas,请更换浏览器尝试~')
        }
    }

</script>

效果图:

使用canvas来完成线性渐变和径向渐变的功能的方法示例

大家可以试着改变一下参数来看看会有什么不同的效果。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

HTML / CSS 相关文章推荐
CSS3中Transform动画属性用法详解
Jul 04 HTML / CSS
IE滤镜与CSS3效果(详细整理分享)
Jan 25 HTML / CSS
CSS3盒子模型详解
Apr 24 HTML / CSS
细说CSS3中box属性中的overflow-x属性和overflow-y属性值的效果
Jul 21 HTML / CSS
HTML5 对各个标签的定义与规定:body的介绍
Jun 21 HTML / CSS
HTML5之SVG 2D入门13—svg对决canvas及长处和适用场景分析
Jan 30 HTML / CSS
HTML5语音识别标签写法附图
Nov 18 HTML / CSS
HTML5 video 事件应用示例
Sep 11 HTML / CSS
关于解决iframe标签嵌套问题的解决方法
Mar 04 HTML / CSS
html5跳转小程序wx-open-launch-weapp踩坑
Dec 02 HTML / CSS
解决flex布局中子项目尺寸不受flex-shrink限制
May 11 HTML / CSS
clear 万能清除浮动(clearfix:after)
May 21 HTML / CSS
浅析canvas元素的html尺寸和css尺寸对元素视觉的影响
Jul 22 #HTML / CSS
详解通过focusout事件解决IOS键盘收起时界面不归位的问题
Jul 18 #HTML / CSS
详解window.open被浏览器拦截的解决方案
Jul 18 #HTML / CSS
data:image data url 文件转为Blob上传后端的方法
Jul 16 #HTML / CSS
基于Html5 canvas实现裁剪图片和马赛克功能及又拍云上传图片 功能
Jul 09 #HTML / CSS
Html5移动端适配IphoneX等机型的方法
Jun 25 #HTML / CSS
微信小程序之html5 canvas绘图并保存到系统相册
Jun 20 #HTML / CSS
You might like
PHP合并数组+与array_merge的区别分析
2010/08/01 PHP
用PHP编写和读取XML的几种方式
2013/01/12 PHP
php上传图片类及用法示例
2016/05/11 PHP
thinkphp框架page类与bootstrap分页(美化)
2017/06/25 PHP
禁止JQuery中的load方法装载IE缓存中文件的方法
2009/09/11 Javascript
jcarousellite.js 基于Jquery的图片无缝滚动插件
2010/12/30 Javascript
Eclipse下jQuery文件报错出现错误提示红叉
2014/01/13 Javascript
浅谈Jquery核心函数
2015/06/18 Javascript
JS实现支持多选的遍历下拉列表代码
2015/08/20 Javascript
jquery+css实现绚丽的横向二级下拉菜单-附源码下载
2015/08/23 Javascript
JavaScript文档碎片操作实例分析
2015/12/12 Javascript
利用Jquery队列实现根据输入数量显示的动画
2016/09/01 Javascript
关于微信jssdk实现多图片上传的一点心得分享
2016/12/13 Javascript
nodeJS服务器的创建和重新启动的实现方法
2018/05/12 NodeJs
vue组件name的作用小结
2018/05/23 Javascript
BootStrap模态框闪退问题实例代码详解
2018/12/10 Javascript
js抽奖转盘实现方法分析
2020/05/16 Javascript
如何在JavaScript中使用localStorage详情
2021/02/04 Javascript
[01:02:48]2018DOTA2亚洲邀请赛小组赛 A组加赛 Newbee vs Liquid
2018/04/03 DOTA
[38:31]完美世界DOTA2联赛PWL S3 Magma vs GXR 第一场 12.13
2020/12/17 DOTA
深入理解Python中的 __new__ 和 __init__及区别介绍
2018/09/17 Python
Python 日期区间处理 (本周本月上周上月...)
2019/08/08 Python
python 多进程并行编程 ProcessPoolExecutor的实现
2019/10/11 Python
Python网络编程之使用TCP方式传输文件操作示例
2019/11/01 Python
对python中assert、isinstance的用法详解
2019/11/27 Python
python关于变量名的基础知识点
2020/03/03 Python
探秘TensorFlow 和 NumPy 的 Broadcasting 机制
2020/03/13 Python
在Ubuntu中安装并配置Pycharm教程的实现方法
2021/01/06 Python
移动端html5模拟长按事件的实现方法
2018/09/30 HTML / CSS
应届毕业生求职信
2013/11/30 职场文书
2014年乡镇领导个人整改措施
2014/09/19 职场文书
社区工作者个人总结
2015/02/28 职场文书
毕业生政审意见范文
2015/06/04 职场文书
工作态度怎么写
2015/06/25 职场文书
python中的class_static的@classmethod的巧妙用法
2021/06/22 Python
Python matplotlib绘制雷达图
2022/04/13 Python