《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)

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

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

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

目录
相关文章
|
6月前
|
监控 负载均衡 JavaScript
有哪些有效的方法可以优化Node.js应用的性能?
有哪些有效的方法可以优化Node.js应用的性能?
356 69
|
6月前
|
前端开发 算法 API
构建高性能图像处理Web应用:Next.js与TailwindCSS实践
本文分享了构建在线图像黑白转换工具的技术实践,涵盖技术栈选择、架构设计与性能优化。项目采用Next.js提供优秀的SSR性能和SEO支持,TailwindCSS加速UI开发,WebAssembly实现高性能图像处理算法。通过渐进式处理、WebWorker隔离及内存管理等策略,解决大图像处理性能瓶颈,并确保跨浏览器兼容性和移动设备优化。实际应用案例展示了其即时处理、高质量输出和客户端隐私保护等特点。未来计划引入WebGPU加速、AI增强等功能,进一步提升用户体验。此技术栈为Web图像处理应用提供了高效可行的解决方案。
|
5月前
|
JavaScript Linux 内存技术
Debian 11系统下Node.js版本更新方法详解
本指南详细介绍在Linux系统中安装和管理Node.js的步骤。首先检查现有环境,包括查看当前版本和清除旧版本;接着通过NodeSource仓库安装最新版Node.js并验证安装结果。推荐使用nvm(Node Version Manager)进行多版本管理,便于切换和设置默认版本。同时,提供常见问题解决方法,如权限错误处理和全局模块迁移方案,以及版本回滚操作,确保用户能够灵活应对不同需求。
488 0
|
5月前
|
JavaScript Linux 内存技术
Debian 11系统下Node.js版本更新方法
Debian 11更新Node.js主要就是这三种方式,无论你是初涉其中的新手还是找寻挑战的专家,总有一种方式能满足你的需求。现在,你已经是这个
558 80
|
5月前
|
机器学习/深度学习 JavaScript 前端开发
JS进阶教程:递归函数原理与篇例解析
通过对这些代码示例的学习,我们已经了解了递归的原理以及递归在JS中的应用方法。递归虽然有着理论升华,但弄清它的核心思想并不难。举个随手可见的例子,火影鸣人做的影分身,你看到的都是同一个鸣人,但他们的行为却能在全局产生影响,这不就是递归吗?雾里看花,透过其间你或许已经深入了递归的魅力之中。
245 19
|
7月前
|
前端开发 JavaScript Java
【Java进阶】JavaScript电灯开关实例:从理论到实践
这个例子展示了JavaScript的基本功能,包括操作HTML元素,监听事件,以及改变元素的样式。通过学习和理解这个例子,你可以了解到JavaScript在网页中的应用,以及如何使用JavaScript来创建交互式的网页。
164 13
|
6月前
|
人工智能 监控 前端开发
基于 Next.js 的书法字体生成工具架构设计与 SSR 优化实践
本项目是一款书法字体生成工具,采用 Next.js 14(App Router)与 Tailwind CSS 构建前端,阿里云 Serverless 部署后端。通过混合渲染策略(SSG/SSR/CSR)、Web Worker 异步计算及 CDN 字体分片加载优化性能。服务端借助阿里云函数计算处理计算密集型任务,将平均耗时从 1200ms 降至 280ms,支持 1000+ QPS。动态路由与 ARMS 监控提升工程化水平,未来计划引入 WebGPU 和 AI 字体风格迁移技术,进一步优化用户体验。
|
7月前
|
JavaScript 前端开发 Java
js 垃圾回收机制的方法
JS回收机制方法讲解
|
8月前
|
监控 JavaScript 前端开发
MutationObserver详解+案例——深入理解 JavaScript 中的 MutationObserver:原理与实战案例
MutationObserver 是一个非常强大的 API,提供了一种高效、灵活的方式来监听和响应 DOM 变化。它解决了传统 DOM 事件监听器的诸多局限性,通过异步、批量的方式处理 DOM 变化,大大提高了性能和效率。在实际开发中,合理使用 MutationObserver 可以帮助我们更好地控制 DOM 操作,提高代码的健壮性和可维护性。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
MutationObserver详解+案例——深入理解 JavaScript 中的 MutationObserver:原理与实战案例
|
8月前
|
移动开发 运维 供应链
通过array.some()实现权限检查、表单验证、库存管理、内容审查和数据处理;js数组元素检查的方法,some()的使用详解,array.some与array.every的区别(附实际应用代码)
array.some()可以用来权限检查、表单验证、库存管理、内容审查和数据处理等数据校验工作,核心在于利用其短路机制,速度更快,节约性能。 博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
下一篇
oss云网关配置