p5.js 渐变填充的实现方式

本文简介

p5.js 作为一款艺术类的 canvas 库,对颜色方面的支持是挺下功夫的,比如本文要介绍的渐变方法。


lerpColor()

要实现渐变效果,可以使用 lerpColor() 方法。

lerpColor 的作用是混合两个颜色以找到一个介于它们之间的颜色。

语法是这样的:

lerpColor(c1, c2, amt)
  • c1: 开始颜色
  • c2: 结束颜色
  • amt: 介于0和1的数字

举个例子,我想取出红色和蓝色中间的那个过渡颜色的值,可以这样写

file

function setup() {createCanvas(300, 300)noStroke()const red = color(255, 0, 0)const blue = color(0, 0, 255)const interim = lerpColor(red, blue, 0.5)fill(red)rect(10, 10, 30, 60)fill(interim)rect(40, 10, 30, 60)fill(blue)rect(70, 10, 30, 60)console.log(interim)
}

在这个例子中,我使用红色和蓝色作为基础色,使用 lerpColor() 方法获取这两个色的中间值,最终出来的效果是紫色。

我分别将这3个颜色填充到3个矩形里。

最后我在控制台输出这个过渡颜色:

file



线性渐变 1

基于上面这个特性,如果我们把矩形的数量增多,把矩形的宽度变小就能实现线性渐变的效果。

和前一个例子一样,从红色渐变到蓝色。我分20个方块慢慢渐变过去。

file

function setup() {createCanvas(400, 400)noStroke()// 创建渐变颜色let red = color(255, 0, 0) // 起始颜色(红色)let blue = color(0, 0, 255) // 终止颜色(蓝色)// 在矩形中应用渐变填充for (let i = 0; i < 20; i++) {let amt = i / 20 // 计算渐变百分比let c = lerpColor(red, blue, amt) // 计算渐变颜色fill(c)rect(i * 20, 0, 20, height)}
}

通过 for 循环20次,每次生成一个 20 * 400 的矩形,根据循环时的 i 值计算每个矩形应该出现的位置 rect(i * 20, 0, 20, height)

最最重要的是 amt ,每次循环都会计算本次循环生成的矩形的渐变颜色。可以自己在控制台输出 amt


如果理解了这个例子,我们再试试把每个矩形的宽度设为1,创建400个矩形实现渐变。

file

function setup() {createCanvas(400, 400)noStroke()// 创建渐变颜色let c1 = color(255, 0, 0) // 起始颜色(红色)let c2 = color(0, 0, 255) // 终止颜色(蓝色)// 在矩形中应用渐变填充for (let i = 0; i < width; i++) {let amt = map(i, 0, width - 1, 0, 1) // 计算渐变百分比let c = lerpColor(c1, c2, amt) // 计算渐变颜色fill(c)rect(i, 0, 1, height)}
}

这次看上去就更加丝滑了,工友们可以自己在控制台输出 amt ,看看每次循环时渐变百分比的变化。



线性渐变2

上面的渐变方法看上去有点笨拙,按照上面的逻辑我们如果要换个渐变角度,实现起来就更加困难了。

canvas 本身是支持渐变的,我在《Canvas 从进阶到退学》里有提到过。

p5.js 作为一款 canvas 库,很自觉的提供了 drawingContext 给开发者访问 canvas 上下文。

我们就可以通过这个方法去实现渐变。

比如我想让红蓝渐变从左上角往右下角过渡,可以这么写:

file

function setup() {createCanvas(400, 400)noStroke()// 创建线性渐变let gradient = drawingContext.createLinearGradient(0, 0, width, height // 渐变起始和终止坐标)gradient.addColorStop(0, 'red') // 渐变起始颜色gradient.addColorStop(1, 'blue') // 渐变终止颜色// 应用线性渐变填充drawingContext.fillStyle = gradientrect(0, 0, width, height)
}

这属于 canvas 的基础知识,还不太了解的工友可以查阅 《Canvas 从进阶到退学》渐变章节。



径向渐变

要实现径向渐变,我们也同样用回前面说的『线性渐变2』的方法。

file

function setup() {createCanvas(400, 400)noStroke()// 创建径向渐变let gradient = drawingContext.createRadialGradient(width / 2, height / 2, 50, // 渐变中心坐标width / 2, height / 2, 200 // 渐变半径)gradient.addColorStop(0, 'red') // 渐变起始颜色gradient.addColorStop(1, 'blue') // 渐变终止颜色// 应用径向渐变填充drawingContext.fillStyle = gradientrect(0, 0, width, height)
}

这个同样是 canvas 的基础知识。

上面的代码用到 widthheightp5.js 提供的变量,这是画布的宽度和高度的意思。



小题目

在 《Canvas 从进阶到退学》 里提到 canvas 可以设置描边渐变,那在 p5.js 里应该如何实现描边渐变呢?



推荐阅读

👍《p5.js 光速入门》

👍《p5.js 使用npm安装p5.js后如何使用?》

👍《p5.js 3D图形-立方体》

👍《p5.js 开发点彩画派的绘画工具》

👍《p5.js画布操作实战:创建,绑定指定元素,动态调整大小,隐藏滚动条,删除画布》

👍《p5.js 视频播放指南》



点赞 + 关注 + 收藏 = 学会了 代码仓库

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/151161.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MySQL数据库——视图的更新、视图作用以及案例

目录 视图的更新 介绍 示例 视图作用 案例 视图的更新 介绍 要使视图可更新&#xff0c;视图中的行与基础表中的行之间必须存在一对一的关系。 如果视图包含以下任何一项&#xff0c;则该视图不可更新&#xff1a; 聚合函数或窗口函数&#xff08;SUM()、MIN()、MAX()…

北太天元安装教程 及使用方法

北太天元是面向科学计算与工程计算的国产通用型科学计算软件。提供科学计算、可视化、交互式程序设计&#xff0c;具备丰富的底层数学函数库&#xff0c;支持数值计算、数据分析、数据可视化、数据优化、算法开发等工作&#xff0c;并通过SDK与API接口&#xff0c;扩展支持各类…

扫地机器人,不相信视觉导航

不可置否&#xff0c;激光雷达已经成为扫地机器人的“耶路撒冷”。 导航技术的从无到有 回顾扫地机器人的兴衰&#xff0c;本质是导航技术的从无到有、从弱到强、从少到多&#xff0c;而在这个过程中&#xff0c;激光雷达无疑发挥了无可替代的作用。2010年&#xff0c;第一台…

JSON(详解)

目录 什么是JSON&#xff1f; 哪里会用到JSON&#xff1f; JSON的特点 JSON的优点 JSON的缺点 JSON和cJSON的关系 什么是JSON&#xff1f; JSON&#xff08;JavaScript Object Notation&#xff09;是一种轻量级的数据交换格式。它以易于阅读和编写的文本格式来存储和表示…

Qwt QwtLegend和QwtPlotLegendItem图例类详解

1.概述 QwtLegend类是Qwt绘图库中用于显示图例的类。图例用于标识不同曲线、绘图元素或数据的意义&#xff0c;以便用户能够更好地理解图表中的数据。通过QwtLegend类&#xff0c;可以方便地在图表中添加、删除和设置图例的位置、方向和样式等属性。 QwtPlotLegendItem类是Qwt…

如何在Windows和Linux系统上监听文件夹的变动?

文章目录 如何在Windows和Linux系统上监听文件夹的变动&#xff1f;读写文件文件系统的操作缓冲和流文件改变事件 如何在Windows和Linux系统上监听文件夹的变动&#xff1f; libuv库实现了监听整个文件夹的修改。本文详细介绍libuv库文件读写和监听的的实现方法。libuv库开发了…

阿里云对象存储OSS文件无法预览,Bucket设置了Referer

您发起的请求头中没有Referer字段或Referer字段为空&#xff0c;与请求Bucket设置的防盗链策略不相符。 解决方案 您可以选择以下任意方案解决该问题。 在请求中增加Referer请求头。 GET /test.txt HTTP/1.1 Date: Tue, 20 Dec 2022 08:48:18 GMT Host: BucketName.oss-examp…

存储器概述

一、存储系统基本概念

『Linux』补丁制作指南

前言 我们在参与某些开源项目的过程当中&#xff0c;经常会遇到漏洞之类的问题&#xff0c;需要我们打补丁解决。尤其是 Linux 源码&#xff0c;源码代码量较多&#xff0c;在修改完内核并发布新内核的时候&#xff0c;基本采用补丁的方式进行发布&#xff0c;而不是将整个内核…

修炼k8s+flink+hdfs+dlink(六:学习namespace,service)

一&#xff1a;什么是namespace&#xff1f; 你可以认为namespaces是你kubernetes集群中的虚拟化集群。在一个Kubernetes集群中可以拥有多个命名空间&#xff0c;它们在逻辑上彼此隔离。 他们可以为您和您的团队提供组织&#xff0c;安全甚至性能方面的帮助&#xff01; 二&a…

QGIS008:QGIS拓扑检查、修改及验证

摘要&#xff1a;本文介绍使用QGIS拓扑检查器和几何图形检查器检查图层的拓扑错误&#xff0c;修改拓扑错误&#xff0c;并对修改后的图层进行错误验证。 实验数据&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/1Vy2s-KYS-XJevqHNdavv9A?pwdf06o 提取码&#xff1a…

Linux学习第24天:Linux 阻塞和非阻塞 IO 实验(一): 挂起

Linux版本号4.1.15 芯片I.MX6ULL 大叔学Linux 品人间百味 思文短情长 在正式开始今天的笔记之前谈一下工作中遇见的一个问题。 本篇笔记主要学习Linux 阻塞和非阻塞 IO 实验&#xff0c;主要包括阻塞和非阻塞简介、等待队列、轮询、…