《JS原理、方法与实践》- canvas作图(三)- 修改颜色和样式

简介: 《JS原理、方法与实践》- canvas作图(三)- 修改颜色和样式

颜色和样式是通过strokeStyle和fillStyle两个属性修改的,它们的默认值都是black,strokeStyle表示画线(描边)用的样式,fillStyle表示填充用的样式,它们可以被赋予三种类型的值:纯色、渐变和模式。

#### 纯色

纯色有以下三种赋值方法:

* 直接赋予颜色值,包括赋予十六进制和颜色的单词,例如#323232、red等

* 使用rgb函数赋值,rgb函数有三个十进制(0~255)的参数,分别表示红、绿、蓝的值

* 使用rgba函数赋值,rgba函数在rgb函数的基础上添加了透明度(alpha),它用第四个参数表示透明度。透明度的取值范围为【0,1】,其中,0表示完全透明,1表示完全不透明。

示例:

```html

<body>

   <canvas id='c2d'>浏览器不支持canvas</canvas>

   <script>

       const canvas = document.getElementById('c2d');

       if (canvas.getContext) {

           let ctx = canvas.getContext('2d');

           ctx.fillStyle = "blue";

           ctx.beginPath();

           ctx.rect(0,0,20,20);

           ctx.fill();

           ctx.fillStyle = "rgb(249,27,27)";

           ctx.beginPath();

           ctx.rect(20,20,20,20);

           ctx.fill();

           ctx.fillStyle = "rgb(249,27,27, 0.5)";

           ctx.beginPath();

           ctx.rect(40,40,20,20);

           ctx.fill();  

       }

   </script>

</body>

```

![](https://upload-images.jianshu.io/upload_images/2789632-92994e54b035981a.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

#### 渐变

渐变的颜色是通过CanvasGradient对象来表示的,它可以使用下面两个方法来创建:

* createLinearGradient(x0,y0,x1,y1): 创建线性渐变

* createRadialGradient(x0,y0,x1,y1,r1): 创建径向渐变,也就是散渐变

CanvasGradient对象包含一个addColorStop方法,用来添加渐变的颜色控制点,语法如下:

```javascript

addColorStop(offset,color)

```

offset用于设置控制点,取值范围【0,1】;color用于设置控制点的颜色。

示例:

```html

<body>

   <canvas id='c2d'>浏览器不支持canvas</canvas>

   <script>

       const canvas = document.getElementById('c2d');

       if (canvas.getContext) {

           let ctx = canvas.getContext('2d');

           let lineGradient = ctx.createLinearGradient(20,20,100,150);  

           lineGradient.addColorStop(0, 'red');            

           lineGradient.addColorStop(0.5, 'rgba(255,255,0,0.7)');            

           lineGradient.addColorStop(1, '#ff6d00');

           ctx.fillStyle = lineGradient;

           ctx.beginPath();

           ctx.arc(50,50,30,0,2*Math.PI);

           ctx.fill();    

           let radiaGradient = ctx.createRadialGradient(130,50,10,130,50,30);

           radiaGradient.addColorStop(0,'rgba(255,204,205,0.3)');      

           radiaGradient.addColorStop(0.5,'#ffff00');      

           radiaGradient.addColorStop(1,'#ff6d00');  

           ctx.fillStyle = radiaGradient;

           ctx.fillRect(100,20,60,60);      

       }

   </script>

</body>

```

![](https://upload-images.jianshu.io/upload_images/2789632-e0742a6c436a4b09.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

#### 模式

模式使用CanvasPattern对象来表示的,它使用createPattern方法来创建,语法如下:

```javascript

createPattern(image,repetition);

```

参数中,image为CanvasImageSource类型,它可以是html中的img节点、video节点、canvas节点或者CanvasRenderingContext2D对象。repetion为重复方式,它可以取下面4个值:

* repeat: 水平和竖直两个方向重复

* repeat-x: 水平重复

* repeat-y: 竖直重复

* no-repeat: 不重复

模式的用法就好像使用图片作为画笔绘图,其中repetition属性跟css中的background-repeat属性类似。

示例:

```html

<body>

   <canvas id='c2d'>浏览器不支持canvas</canvas>

   <script>

       const canvas = document.getElementById('c2d');

       if (canvas.getContext) {

           let ctx = canvas.getContext('2d');

           var img = new Image();

           img.src = 'https://mdn.mozillademos.org/files/222/Canvas_createpattern.png';

           img.onload = function () {

               var pattern = ctx.createPattern(img, 'repeat');

               ctx.fillStyle = pattern;

               ctx.fillRect(0, 0, 400, 400);

           };

       }

   </script>

</body>

```

![](https://upload-images.jianshu.io/upload_images/2789632-a52a8de2449fa8f1.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

如果我的博客对你有帮助、如果你喜欢我的博客内容,请 “点赞” “评论” “收藏” 一键三连哦!

听说 👉 点赞 👈 的人运气不会太差,每一天都会元气满满哦 嘿嘿!!! ❤️ ❤️ ❤️

大家的支持就是我坚持下去的动力。点赞后不要忘了👉 关注 👈我哦!

目录
相关文章
|
13天前
|
缓存 监控 前端开发
JavaScript 实现大文件上传的方法
【10月更文挑战第17天】通过以上步骤和方法,我们可以实现较为可靠和高效的大文件上传功能。当然,具体的实现方式还需要根据实际的应用场景和服务器要求进行调整和优化。
|
23小时前
|
JavaScript 前端开发 图形学
JavaScript 中 Math 对象常用方法
【10月更文挑战第29天】JavaScript中的Math对象提供了丰富多样的数学方法,涵盖了基本数学运算、幂运算、开方、随机数生成、极值获取以及三角函数等多个方面,为各种数学相关的计算和处理提供了强大的支持,是JavaScript编程中不可或缺的一部分。
|
6天前
|
JavaScript 前端开发 Go
异步加载 JS 的方法
【10月更文挑战第24天】异步加载 JavaScript 是提高网页性能和用户体验的重要手段。通过使用不同的方法和技术,可以实现灵活、高效的异步加载 JavaScript。在实际应用中,需要根据具体情况选择合适的方法,并注意处理可能出现的问题,以确保网页能够正常加载和执行。
|
17天前
|
人工智能 JavaScript 网络安全
ToB项目身份认证AD集成(三完):利用ldap.js实现与windows AD对接实现用户搜索、认证、密码修改等功能 - 以及针对中文转义问题的补丁方法
本文详细介绍了如何使用 `ldapjs` 库在 Node.js 中实现与 Windows AD 的交互,包括用户搜索、身份验证、密码修改和重置等功能。通过创建 `LdapService` 类,提供了与 AD 服务器通信的完整解决方案,同时解决了中文字段在 LDAP 操作中被转义的问题。
|
18天前
|
存储 JavaScript 前端开发
JavaScript 数据类型详解:基本类型与引用类型的区别及其检测方法
JavaScript 数据类型分为基本数据类型和引用数据类型。基本数据类型(如 string、number 等)具有不可变性,按值访问,存储在栈内存中。引用数据类型(如 Object、Array 等)存储在堆内存中,按引用访问,值是可变的。本文深入探讨了这两种数据类型的特性、存储方式、以及检测数据类型的两种常用方法——typeof 和 instanceof,帮助开发者更好地理解 JavaScript 内存模型和类型检测机制。
38 0
JavaScript 数据类型详解:基本类型与引用类型的区别及其检测方法
|
23小时前
|
Web App开发 JavaScript 前端开发
如何确保 Math 对象的方法在不同的 JavaScript 环境中具有一致的精度?
【10月更文挑战第29天】通过遵循标准和最佳实践、采用固定精度计算、进行全面的测试与验证、避免隐式类型转换以及持续关注和更新等方法,可以在很大程度上确保Math对象的方法在不同的JavaScript环境中具有一致的精度,从而提高代码的可靠性和可移植性。
|
23小时前
|
JavaScript 前端开发 开发者
|
18天前
|
存储 JavaScript 前端开发
JavaScript数组去重的八种方法详解及性能对比
在JavaScript开发中,数组去重是一个常见的操作。本文详细介绍了八种实现数组去重的方法,从基础的双重循环和 indexOf() 方法,到较为高级的 Set 和 Map 实现。同时,分析了每种方法的原理和适用场景,并指出了使用 Set 和 Map 是目前最优的解决方案。通过本文,读者可以深入理解每种方法的优缺点,并选择最合适的数组去重方式。
32 0
|
19天前
|
JavaScript 前端开发 应用服务中间件
vue前端开发中,通过vue.config.js配置和nginx配置,实现多个入口文件的实现方法
vue前端开发中,通过vue.config.js配置和nginx配置,实现多个入口文件的实现方法
93 0
|
19天前
|
JavaScript
深入解析:JS与Vue中事件委托(事件代理)的高效实现方法
深入解析:JS与Vue中事件委托(事件代理)的高效实现方法
24 0