问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

如何使用HTML5 CANVAS绘制渐变色

发布网友 发布时间:2023-06-13 18:26

我来回答

1个回答

热心网友 时间:2024-12-13 04:32


HTML5 Canvas渐变是一种用于填充或描边图形的颜色模式。渐变色是由不同的颜色进行过渡,而不是单一的颜色。先来看几个canvas渐变色的例子:
渐变按照类型来分可以分为两种类型:
线性渐变
径向渐变
线性渐变以线性的模式来改变颜色,也就是水平,垂直或对角方向。
径向渐变以圆形模式来改变颜色,颜色以圆形的中心向外辐射。
线性渐变
正如前面所说,线性渐变以线性的模式来改变颜色。我们可以通过2D上下文的createLinearGradient()方法来创建一个线性渐变。下面是一个例子:
var canvas = document.getElementById(ex1);
var context = canvas.getContext(2d);
var x1 = 0;
var y1 = 0;
var x2 = 100;
var y2 = 0;
var linearGradient1 = context.createLinearGradient(x1,y1,x2,y2);
createLinearGradient()函数有4个参数:x1,y1,x2和y2。这4个参数决定渐变的方向和距离。线性渐变会从第一个点(x1,y1)扩展到第二个点(x2,y2)。
水平的线性渐变仅仅是水平方向的参数值(x1和x2)不同,例如:
var x1 = 0;
var y1 = 0;
var x2 = 100;
var y2 = 0;
var linearGradient1 = context.createLinearGradient(x1,y1,x2,y2);
垂直的线性渐变仅仅是垂直方向的参数值(y1和y2)不同,例如:
var x1 = 0;
var y1 = 0;
var x2 = 0;
var y2 = 100;
var linearGradient1 = context.createLinearGradient(x1,y1,x2,y2);
一个对角线的线性渐变水平和垂直方向上的参数都不相同,例如:
var x1 = 0;
var y1 = 0;
var x2 = 100;
var y2 = 100;
var linearGradient1 = context.createLinearGradient(x1,y1,x2,y2);
颜色停止点(Color Stops)
在上面的例子中,并没有指明线性渐变使用什么颜色。为了指明使用什么渐变颜色,可以在渐变对象上使用addColorStop()方法来指定。例如:
var linearGradient1 = context.createLinearGradient(0,0,100,0);
linearGradient1.addColorStop(0, rgb(255, 0, 0));
linearGradient1.addColorStop(1, rgb( 0, 0, 0));
addColorStop()方法有两个参数。第一个参数是0-1之间的一个数值,这个数值指定该颜色进入渐变多长的距离,第二个参数是颜色值,例子中使用的是rgb()颜色值。
在上面的例子中为渐变添加了两种颜色。第一种颜色是红色,设置在渐变的开始处。第二种颜色是黑色,设置在渐变的结束处。
你可以添加通过addColorStop()函数来添加更多的颜色。例如下面的例子添加了三种颜色:
var linearGradient1 = context.createLinearGradient(0,0,100,0);
linearGradient1.addColorStop(0 , rgb(255, 0, 0));
linearGradient1.addColorStop(0.5, rgb( 0, 0, 255);
linearGradient1.addColorStop(1 , rgb( 0, 0, 0));
复制代码
上面的代码在渐变的中间添加了一个蓝色。整个渐变将平滑的从红色过渡到蓝色,在过渡到黑色。
使用渐变来填充和描边图形
你可以使用渐变来填充或描边图形。要填充或描边图形可以通过2D上下文的fillStyle或strokeStyle属性来完成。下面是一个示例代码:
var linearGradient1 = context.createLinearGradient(0,0,100,0);
linearGradient1.addColorStop(0 , rgb(255, 0, 0));
linearGradient1.addColorStop(0.5, rgb( 0, 0, 255);
linearGradient1.addColorStop(1 , rgb( 0, 0, 0));
context.fillStyle = linearGradient1;
context.strokeStyle = linearGradient1;
#p#副标题#e#
通过fillStyle或strokeStyle属性来指向渐变对象即可完成渐变的填充或描边。
现在我们可以为图形填充渐变色或描边渐变色。下面是一个例子,一个矩形的填充渐变色和一个矩形的描边渐变色。
var canvas = document.getElementById(ex2);
var context = canvas.getContext(2d);
var linearGradient1 = context.createLinearGradient(0,0,100,0);
linearGradient1.addColorStop(0 , rgb(246, 36, 89));
linearGradient1.addColorStop(0.5, rgb( 31, 58, 147));
linearGradient1.addColorStop(1 , rgb( 34, 49, 63));
context.fillStyle = linearGradient1;
context.fillRect(10,10,100, 100);
var linearGradient2 = context.createLinearGradient(125,0, 225,0);
linearGradient2.addColorStop(0 , rgb(255, 0, 0));
linearGradient2.addColorStop(0.5, rgb( 0, 0, 255));
linearGradient2.addColorStop(1 , rgb( 0, 0, 0));
context.strokeStyle = linearGradient2;
context.strokeRect(125, 10, 100, 100);
渐变的长度
我们在使用渐变的时候要非常明白的知道渐变的长度的概念。如果我们设置渐变从x=10扩展到x=110的距离,那么渐变只会作用在水平方向上从10到110的距离的范围内。超出这个范围的图形将任然受渐变色的影响,但是在这个范围之外的颜色只会是渐变的开始或结束颜色。
距离来说,加入有一个水平线性渐变,x1=150,x2=350。渐变从蓝色过渡到绿色。那么所有水平方向定位x值小于150的图形都会使用蓝色蓝填充。所有水平方向定位x值大于350的图形都会使用绿色来填充。只有那些在水平方向定位x值在150到350之间的图形会使用蓝绿渐变色来填充。
具体来看下面的代码,这里绘制了5个矩形,并用上面所说的渐变来填充它们,让我们来看看效果:
var linearGradient1 = context.createLinearGradient(150, 0, 350,0);
linearGradient1.addColorStop(0, rgb(0, 0, 255));
linearGradient1.addColorStop(1, rgb(0, 255, 0));
context.fillStyle = linearGradient1;
context.fillRect(10,10,130, 100);
context.fillRect(150,10, 200, 100);
context.fillRect(360,10, 130, 100);
context.fillRect(100,120, 150, 100);
context.fillRect(280,120, 150, 100);
从上面的结果可以看出,在渐变区域之外的图形仅会使用开始或结束颜色来填充。
渐变长度是非常重要的概念,需要大家仔细体会。只有掌握它才能在使用渐变是获得正确的结果。
径向渐变
径向渐变是一种圆形的颜色扩展模式,颜色从圆心位置开始向外辐射。下面是一个例子:
一个径向渐变于两个圆形来定义。每一个圆都有一个圆心和一条半径。下面是示例代码:
var x1 = 100; // 第一个圆圆心的X坐标
var y1 = 100; // 第一个圆圆心的Y坐标
var r1 = 30; // 第一个圆的半径
var x2 = 100; // 第二个圆圆心的X坐标
var y2 = 100; // 第二个圆圆心的Y坐标
var r2 = 100; // 第二个圆的半径
var radialGradient1 =
context.createRadialGradient(x1, y1, r1, x2, y2, r2);
radialGradient1.addColorStop(0, rgb(0, 0, 255));
radialGradient1.addColorStop(1, rgb(0, 255, 0));
context.fillStyle = radialGradient1;
context.fillRect(10,10, 200, 200);
如上面的代码所示,这里有两个圆,圆心分别为x1,y1和x2,y2,它们的半径分别为r1和r2,这些值将作为参数传入到2D上下文的createRadialGradient()方法中。
这两个圆必须设置不同的半径,形成一个内圆和一个外圆。这样渐变色就从一个圆形辐射到另一个圆形。
颜色停止点会被添加到这两个圆形之间,例如上面的代码中,第一个颜色停止点中的参数0表示该颜色从第一个圆形开始,第二个颜色停止点中的参数1表示第二种颜色从第二个圆形开始。
下面是上面代码的返回结果:
如果两个圆形的圆心位置相同,那么径向渐变将是一个完整的圆形。如果两个圆的圆心位置不相同,那么径向渐变看起来就像是一个探照灯发出的光线。例如下面的样子:
var x1 = 100;
var y1 = 100;
var r1 = 30;
var x2 = 150;
var y2 = 125;
var r2 = 100;
var radialGradient1 = context.createRadialGradient(x1, y1, r1, x2, y2, r2);
radialGradient1.addColorStop(0, rgb(0, 0, 255));
radialGradient1.addColorStop(1, rgb(0, 255, 0));
context.fillStyle = radialGradient1;
context.fillRect(10,10, 200, 200);
得到的结构如下所示:
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
和面的和是什么读音? win10 应用打不开。全都打不开。 进入win10打不开软件 win10电脑软件都打不开是什么原因win10突然软件都打不开软件是怎么回事... 软件打不开怎么办win10电脑点不开软件最简单办法 请问下,离厦门市岛内的台湾路的国联大厦最近的建设银行和农业银行... 从巴黎都市到建设银行怎么坐公交车,最快需要多久 东莞万江官桥窖离建设银行哪路车最近? 建行七支分行有那些公交车经过 佛山哪里有飞越丛林拓展 晚晌[wǎn shǎng]什么意思?近义词和反义词是什么?英文翻译是什么... 如何查询企业注册信息? 怎么查询公司注册信息 灵越14z5423加了一条4G内存后,显示安装内存8G,可用3.13G 戴尔14z5423 inspiron 14z 5423什么时候上市的? 普洱湿仓怎么退仓 什么软件可以先充话费 抖音极速版1分钱充20元话费是真的吗 steam创意工坊文件在哪里? 大学生贷款不还会怎么样? 北京女子图鉴张超再遇陈可是哪几 盗窃罪主动退赃派出所直接取保候审还拘留吗? 非法经营退赃后取保能缓刑吗 非法经营主动退赃后取保候审 检察院退赃后还会判刑吗 取保候审而且退赃了一般怎么判 退赃后取保候审基本没事了吗 合肥社保增加人员流程 合肥企业新增社保人员 威纶触摸屏点击位置坐标提前 linux中文件i/o有哪些接口函数,读取触摸屏坐标的流程是 上海意铁实业有限公司怎么样? 上海2019年环球港附近拆迁的房子有哪些 上海志铁实业有限公司怎么样? 以下不属于妊高征患者临床表现的是: 李倩在1942漏奶在多少分钟 文明6单人模式秘籍有哪些? ...马尔泰若曦不是格格吗 入宫选秀女没有选上就只能在宫里当宫女 什么... 小学一年级优秀作文200字七篇 小学一年级作文200字左右八篇 小学一年级简单作文200字七篇 小学一年级200字作文范文六篇 小学一年级优秀作文200字【八篇】 一年级优秀作文200字左右10篇 甲类功放是晶体管的还是电子管的?超甲类功放是晶体管的还是电子管... 泰州巨腾哪个部门好点 ...思维思考问题的方法田忌赛马告诉了我们什么跳水? 从自相矛盾、跳水、田忌赛马中分别明白了什么? 步步惊心里,若曦可以不参加选秀的么?