使用P5.js来制作一个快乐的小风车动画

news2025/1/21 5:55:06

p5.js简介

前一段时间偶然了解到一个觉得很好玩儿的东西p5.js,于是就去了解了一下,发现可以自己设计一些有趣的动画效果,设计出来的动画可以放置到页面当中,而且也是简单易学的。

下面是一段官方的介绍:

p5.js是一个以 Processing语言(java的图形化语言)为基础的JavaScript 库,经常用于互联网数据可视化和互动艺术创作。它继承了Processing语言的初衷,通过简单的编程即可表达数字创意

home | p5.js (p5js.org),这个是p5.js的教程网站,配套的有远程的p5编辑器链接。但是,由于p5的编译器需要翻外网才能使用,因此,为了服务于大多数群众,本篇博客将使用vscode来实现p5.js的动画效果。

使用vscode来在本地跑p5.js的项目

前期准备

1.去vscode扩展里面搜索p5.js,下载下面这几个拓展应用并且下载

 2.新建个文件夹,使用快捷键,shift+ctrl+p,快速创建一个 p5 project

 3.给自己创建的p5 project 起个项目名字,(这里,我的名字是windMill,因为我们即将要做一个风车动画)

4.此时,我们可以看到默认创建的index.html和sketch.js两个文件

 5.点击侧边栏的雪花按钮,可以看到自己在该文件夹下创建的p5 项目,点击运行按钮,可以在vscode自带的浏览器看到运行的情况

当然也可以直接将html使用浏览器打开查看效果,由于在sketch.js里面,有创建画布

function setup() {
  createCanvas(400, 400);
}
//在js代码中,setup()函数主要用于设置程序初始状态的代码(比如画布大小,刷新频率,色彩模式等等)
//draw()函数主要用户图形绘制的功能代码(色彩填充,绘制图像)

通过F12键进行检查,直接就可以看到有一个400*400的画布

核心代码

sketch.js


function triangleWave(x, t, a, p = 0) {
  const temp = (x + p) / t * 2
  const integer = Math.trunc(temp)
  const fraction = temp - integer
  if (integer % 2 === 0) {
    return a * (fraction - 0.5)
  } else {
    return a * (0.5 - fraction)
  }
}


const speed = 0.01
const period = 1.5
let t = 0

let windmillTower
let windmillFan

function preload() {
  windmillTower = loadImage('asset1/windmill_tower.svg')
  windmillFan = loadImage('asset1/windmill_fan.svg')
}

function setup() {
  createCanvas(500, 500, WEBGL)
}

function draw() {
  background(249, 145, 190)
  scale(1, 1 - triangleWave(t += speed, period, 0.3))
  shearX(PI / 12 * triangleWave(t += speed, 2 * period, 1))
  // rect(-50, -100, 100, 100)
  image(windmillTower, -50, -100, 100, 100)
  push()
  translate(0, -90)
  rotate(10 * t)
  image(windmillFan, -50, -50, 100, 100)
  pop()
}

 风车风叶的svg格式代码

<svg xmlns="http://www.w3.org/2000/svg" width="701.1049" height="701.0992" viewBox="0 0 701.1049 701.0992">
  <title>windmill_fan</title>
  <g id="å¾å±_2" data-name="å¾å± 2">
    <g id="Layer_1" data-name="Layer 1">
      <g>
        <rect x="24.5277" y="562.2764" width="148.6931" height="28.7276" transform="translate(-378.7375 238.7392) rotate(-44.9917)" fill="#d3f0e1"/>
        <polygon points="120.977 483.047 141.286 503.365 246.434 398.223 226.113 377.905 120.977 483.047" fill="#d3f0e1"/>
        <rect x="-1.0611" y="536.6855" width="148.693" height="28.7317" transform="translate(-368.1873 213.2198) rotate(-45)" fill="#d3f0e1"/>
        <polygon points="146.558 508.641 166.88 528.953 272.016 423.808 251.706 403.496 146.558 508.641" fill="#d3f0e1"/>
        <rect x="135.6935" y="-1.0702" width="28.7203" height="148.7007" transform="translate(-7.8672 127.5672) rotate(-45)" fill="#d3f0e1"/>
        <polygon points="61.732 56.456 166.88 161.598 187.201 141.283 82.047 36.132 61.732 56.456" fill="#d3f0e1"/>
        <rect x="246.1119" y="109.351" width="28.7214" height="148.6975" transform="translate(-53.604 237.9907) rotate(-45.0008)" fill="#d3f0e1"/>
        <polygon points="580.133 218.052 559.819 197.74 454.664 302.885 474.986 323.203 580.133 218.052" fill="#d3f0e1"/>
        <polygon points="172.158 166.868 277.3 272.019 297.621 251.701 192.473 146.556 172.158 166.868" fill="#d3f0e1"/>
        <rect x="553.4721" y="135.6839" width="148.7008" height="28.7264" transform="translate(77.843 487.9787) rotate(-45.0097)" fill="#d3f0e1"/>
        <polygon points="488.323 585.403 593.464 690.548 613.78 670.236 508.625 565.085 488.323 585.403" fill="#d3f0e1"/>
        <polygon points="513.911 559.807 619.058 664.958 639.373 644.643 534.219 539.498 513.911 559.807" fill="#d3f0e1"/>
        <rect x="417.4539" y="220.5136" width="148.7064" height="28.7343" transform="translate(-22.0241 416.5968) rotate(-45.0047)" fill="#d3f0e1"/>
        <rect x="451.8566" y="417.4547" width="28.7266" height="148.7006" transform="translate(-211.2058 473.7055) rotate(-44.9993)" fill="#d3f0e1"/>
        <rect x="527.8843" y="110.0902" width="148.6956" height="28.734" transform="translate(88.3121 462.1838) rotate(-44.9876)" fill="#d3f0e1"/>
        <rect x="426.2633" y="443.0435" width="28.7286" height="148.7006" transform="translate(-236.7975 463.1322) rotate(-45.0017)" fill="#d3f0e1"/>
        <path d="M474.9858,333.7535,585.4057,223.33l5.2783-5.2754L701.1049,107.628,675.517,82.0406l-5.2783-5.2725L644.6518,51.1749,534.2251,161.5982l-5.2725,5.27L421.1684,274.6548l-2.6416,2.6426-45.6387,45.6411,5.2725,5.2783,45.6445-45.644L444.12,302.8877l5.2724,5.2754ZM670.2387,87.3194l20.3155,20.3086L585.4057,212.7764l-20.3144-20.312Zm-110.42,110.42,20.3145,20.312L474.9858,323.2027l-20.3213-20.3179ZM449.392,297.6153l-20.3212-20.3179L534.2251,172.146l20.3154,20.3184ZM559.8188,187.1919l-20.3154-20.3242L644.646,61.7256,664.96,82.0435Z" fill="#534b00"/>
        <path d="M328.2226,322.9444l-45.65-45.65,20.3208-20.3208,5.2725-5.2725,25.5815-25.5815-110.42-110.42-5.2725-5.2754L107.622,0,82.0468,25.5845,76.7744,30.857l-25.6,25.5991L161.601,166.8736l5.2788,5.2754L274.6577,279.93l2.6367,2.6363L322.95,328.2256ZM166.88,161.5982,61.7319,56.4561,82.0468,36.1324,187.2006,141.2833Zm25.5933-25.59L87.3251,30.86l20.3091-20.3061,105.148,105.145ZM277.3,272.0186,172.1582,166.8677l20.3149-20.312L297.621,251.7007Zm25.5933-25.59L197.7456,141.2833l20.309-20.3121L323.1967,226.1163Z" fill="#534b00"/>
        <path d="M277.3,418.5352l-20.3149-20.3179-5.2725-5.2724-25.6-25.5962L115.6928,477.772l-5.2724,5.27L0,593.4649l25.5932,25.5962,5.2725,5.2695,25.5937,25.59,110.42-110.42,5.2784-5.2754L279.9365,426.4439l2.6362-2.6392,45.65-45.65-5.2725-5.2754ZM30.872,613.78,10.5571,593.4649,115.6987,488.32l20.3149,20.3208ZM141.2861,503.3653,120.977,483.0474,226.1132,377.9053l20.3208,20.3179ZM56.4594,639.37,36.15,619.0552,141.2861,513.91l20.3149,20.3149ZM166.88,528.9527l-20.3213-20.312,105.148-105.145,20.3091,20.312Z" fill="#534b00"/>
        <path d="M539.5034,534.2193l-5.2783-5.2754L426.4409,421.16l-2.6358-2.6362-45.6445-45.65-5.2842,5.2754,45.65,45.6533-20.3154,20.312-5.2725,5.2754L367.351,474.98,477.7719,585.4029l5.2725,5.2695,110.42,110.4268,25.5938-25.5908,5.2724-5.2813L649.9243,644.64Zm-56.459,45.9023L377.896,474.98l20.3154-20.3178L503.3588,559.8125Zm25.5937-25.5844L403.49,449.3863l20.3154-20.312L528.9467,534.2222Zm84.8262,136.0112L488.3227,585.4029l20.3027-20.3179L613.78,670.2359Zm25.5938-25.5908L513.9106,559.8067l20.3086-20.3091,105.1543,105.145Z" fill="#534b00"/>
      </g>
    </g>
  </g>
</svg>

 风车塔身svg格式图片代码

<svg xmlns="http://www.w3.org/2000/svg" width="361.1963" height="622.5976" viewBox="0 0 361.1963 622.5976">
  <title>windmill_tower</title>
  <g id="å¾å±_2" data-name="å¾å± 2">
    <g id="Layer_1" data-name="Layer 1">
      <g>
        <g>
          <polygon points="180.601 127.207 136.212 127.207 104.463 622.598 180.601 622.598 250.674 622.598 218.919 127.207 180.601 127.207" fill="#e06d4e"/>
          <polygon points="81.644 127.207 0 622.598 104.463 622.598 136.212 127.207 81.644 127.207" fill="#f57856"/>
          <polygon points="279.558 127.207 218.919 127.207 250.674 622.598 361.196 622.598 279.558 127.207" fill="#d16649"/>
        </g>
        <rect x="125.8413" y="478.7353" width="101.2446" height="143.8623" fill="#43778e"/>
        <polygon points="116.612 478.735 176.464 435.811 236.309 478.735 116.612 478.735" fill="#39657a"/>
        <g>
          <path d="M180.601,275.8588a24.26,24.26,0,0,0-24.2661,24.2662v71.13h48.5323v-71.13A24.2645,24.2645,0,0,0,180.601,275.8588Zm18.7173,89.8472H161.8838V300.125a18.7173,18.7173,0,1,1,37.4345,0Z" fill="#b85a40"/>
          <path d="M180.601,281.4072a18.7366,18.7366,0,0,0-18.7172,18.7178v65.581h37.4345V300.125A18.74,18.74,0,0,0,180.601,281.4072Z" fill="#ffe8a1"/>
        </g>
        <path d="M207.8818,550.6582a7.6084,7.6084,0,1,1-7.6084-7.6026A7.6113,7.6113,0,0,1,207.8818,550.6582Z" fill="#ffe8a1"/>
        <g>
          <path d="M259.081,186.0087c-5.7051.3272-10.2685,7.4043-10.2685,16.1417v47.5h14.5439V201.4087A31.8933,31.8933,0,0,0,259.081,186.0087Z" fill="#f5de9b"/>
          <path d="M270.166,202.15c0-8.9537-4.7862-16.211-10.6768-16.211-.1445,0-.27.06-.4082.0693a31.8933,31.8933,0,0,1,4.2754,15.4V249.65h6.81Z" fill="#b85a40"/>
        </g>
        <g>
          <path d="M79.8247,432.7763c0-9.8008-4.9541-17.7451-11.0552-17.7451a5.3977,5.3977,0,0,0-.8887.1475c-1.5615,2.999-4.6,9.7822-4.6,16.9218v52.7276H79.8247Z" fill="#f5de9b"/>
          <path d="M67.8808,415.1787c-5.6865.7353-10.1723,8.2871-10.1723,17.5976v52.0518h5.5727V432.1005C63.2812,424.9609,66.3193,418.1777,67.8808,415.1787Z" fill="#b85a40"/>
        </g>
        <path d="M296.3906,114.9961a115.807,115.807,0,0,0-231.6084,0Z" fill="#0080ab"/>
        <rect x="69.0576" y="114.9961" width="223.0566" height="12.2114" fill="#d16649"/>
        <path d="M225.7529,61.059A41.6118,41.6118,0,1,1,184.144,19.4414,41.607,41.607,0,0,1,225.7529,61.059Z" fill="#007096"/>
        <path d="M218.6425,57.5009a38.0566,38.0566,0,1,1-38.06-38.0595A38.0565,38.0565,0,0,1,218.6425,57.5009Z" fill="#534b00"/>
        <path d="M206.8066,61.6923a23.1612,23.1612,0,1,1-23.1611-23.1582A23.1635,23.1635,0,0,1,206.8066,61.6923Z" fill="none"/>
      </g>
    </g>
  </g>
</svg>

最后的效果

鼠标右键,使用Live Server进行打开

 总之,p5.js可以帮助我们自己平时设计一些好玩儿的动画,增加一些趣味性,对于刚学编程的人来说,也是很友好的

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

0016Java程序设计-springboot幼儿园管理系统

摘 要目 录系统设计开发环境 摘 要 随着科学技术的飞速发展&#xff0c;各行各业都在努力与现代先进技术接轨&#xff0c;通过科技手段提高自身的优势&#xff1b;对于幼儿园管理系统当然也不能排除在外&#xff0c;随着网络技术的不断成熟&#xff0c;带动了幼儿园管理系统&a…

从JVM角度看继承

从JVM角度看继承 最近重读了周志明老师的《深入理解JAVA虚拟机》一书&#xff0c;看完大有收获&#xff0c;但仍对继承情况下对象内存布局有所疑惑&#xff0c;所以查阅资料&#xff0c;结合本书进行分析 参考文档&#xff1a; 【深入理解JVM】&#xff1a;Java类继承关系中…

算法训练营day45|动态规划 part07:完全背包 (LeetCode 70. 爬楼梯(进阶)、322. 零钱兑换、279.完全平方数)

文章目录 70. 爬楼梯(进阶)(求排列方法数)思路分析代码实现 322. 零钱兑换(求等于背包重量的最小物品数)思路分析代码实现思考总结 279.完全平方数 (求等于背包重量的最小物品数)思路分析代码实现 70. 爬楼梯(进阶)(求排列方法数) 题目链接&#x1f525; 假设你正在爬楼梯。需…

jquery jstree的懒加载

效果如下 使用jquery的jstree组件 1.前端准备工作 1.1引入jstree样式和js <link rel"stylesheet" href"/public/vendor/jstree/jstree.css"> <div id"departmentJstree"></div> <script src"/public/vendor/jstree…

Dominosa/数邻(2) | C++ | BFS

目录 一、Dominosa简介二、题目描述三、编程思路四、完整代码 一、Dominosa简介 Dominosa&#xff0c;中文名称为数邻&#xff0c;是一种棋盘游戏&#xff0c;基于骨牌的排列和匹配来进行。它是从骨牌游戏中发展而来的&#xff0c;在骨牌的基础上添加了一些规则和难度。具体的游…

canape中快速配置需要录制参数的技巧

以前在车里录制数据时&#xff0c;大量融合数据一个一个拖拽 &#xff0c;不仅慢&#xff0c;有时心不细的话&#xff0c;还会漏选、挑错。 用正则表达式的挑选方法&#xff0c;可以既快速又准确的挑出所需数据。 以下蓝色字体是操作方法&#xff1a; 正则表达式 示例&#xff…

QTableView通过setColumnWidth设置了列宽无效的问题

在用到QT的QTableView时&#xff0c;为了显示效果&#xff0c;向手动的设置每一列的宽度&#xff0c;但是如下的代码是无效的。 ui->tableView->setColumnWidth(0,150);ui->tableView->setColumnWidth(1,150);ui->tableView->setColumnWidth(2,150);ui->t…

docker-compose安装nginx

基于docker-compose安装nginx 目录 一、目录结构 1、docker-compose.yml 2、nginx.conf 3、default.conf 4、index.html 二、访问测试 一、目录结构 1、docker-compose.yml version: 3 services:nginx:image: registry.cn-hangzhou.aliyuncs.com/zhengqing/nginx:1.21.1…

Linux指令二【进程,权限】

进程是一个具有一定独立功能的程序在一个数据集上的一次动态执行的过程&#xff0c;是操作系统进行 资源分配和调度的一个独立单位&#xff0c;是应用程序运行的载体。 一、进程基本指令 1.ps&#xff1a;当前的用户进程 ps 只显示隶属于自己的进程状态ps -aux 显示所有进程…

C/C++计算(a+b)c的值 2019年9月电子学会青少年软件编程(C/C++)等级考试一级真题答案解析

目录 C/C计算(ab)c的值 一、题目要求 1、编程实现 2、输入输出 二、解题思路 1、案例分析 三、程序代码 四、程序说明 五、运行结果 六、考点分析 C/C计算(ab)c的值 2019年9月 C/C编程等级考试一级编程题 一、题目要求 1、编程实现 给定3个整数a、b、c&#xff0…

错误: 找不到或无法加载主类 Main

在用git回退到上个版本后发现&#xff0c;无法运行项目并提示 错误: 找不到或无法加载主类 Main 可以看到Main前面的图标也是号。 查了半天没有解决&#xff0c;问了个大佬&#xff0c;大佬一下就解决掉了&#xff0c;本文记录下解决过程。 错误原因是编辑器无法找到代码位置&…

java(五)继承和多态,抽象类与接口,异常(javaSE完)

八、继承和多态&#xff08;重要&#xff09; 对于java来说&#xff0c;最重要的就是面对对象&#xff0c;而如何体现这个&#xff0c;在其中三个概念极为重要&#xff0c;封装、继承、多态而无论考试还是面试通常都会考察这几个概念及其原理用法。 1.继承 面向对象思想中提…

Java“牵手”淘宝商品详情数据,淘宝商品详情API接口,淘宝API接口申请指南

淘宝平台商品详情接口是开放平台提供的一种API接口&#xff0c;通过调用API接口&#xff0c;开发者可以获取淘宝商品的标题、价格、库存、月销量、总销量、库存、详情描述、图片等详细信息 。 获取商品详情接口API是一种用于获取电商平台上商品详情数据的接口&#xff0c;通过…

Windows 安装 MariaDB 数据库

之前一直使用 MySQL&#xff0c;使用 MySQL8.0 时候&#xff0c;占用内存比较大&#xff0c;储存空间好像也稍微有点大&#xff0c;看到 MariaDB 是用来代替 MySQL 的方案&#xff0c;之前用着也挺得劲&#xff0c;MySQL8.0 以上好像不能去导入低版本的 sql&#xff0c;或者需要…

MySQL下载安装环境变量配置,常用命令

一、下载安装 mysql官网 下载连接 这个是下载图形安装 https://dev.mysql.com/downloads/installer/ 这个是下载免图形安装 https://dev.mysql.com/downloads/mysql/ 担心个别宝宝没有账号&#xff0c;这边也提供一下&#xff0c;方便下载&#xff1a; 账户&#xff1a;1602404…

宝兰德部署包特别慢部署超时失败问题解决

部署慢问题解决&#xff1a; 默认这块是空的&#xff0c;我改成 G1好像就快了。 刚开始是部署超时也是基于第一个问题的原因&#xff0c;如果你还有其他原因&#xff0c;但是查看服务日志一直显示超时&#xff0c;那可能是你看错日志文件了。 宝兰德操作日志 /data/besapp…

Matlab图像处理-迭代式阈值选择法

基本思想 迭代式阈值选择法的基本思想是&#xff1a;开始时&#xff0c;选择一个阈值作为初始估计值&#xff0c;然后按某种策略不断地改进这一估计值&#xff0c;直到满足给定的准则为止。在迭代过程中&#xff0c;关键之处在于选择什么样的阈值改进策略。好的阈值改进策略应…

学生免费申请IDEA使用流程

IntelliJ IDEA一般简称IDEA&#xff0c;是Java编程语言开发的集成环境&#xff0c;在业界被公认为最好的Java开发工具。 1 IDEA官网下载 1.1 官网地址 https://www.jetbrains.com/idea/ 1.2 IDEA下载 访问官网&#xff0c;单击download按钮&#xff0c;下载“IntelliJ IDE…

【疑难杂症】使用xshell连接云服务器连接不上

目录 【1】使用xshell连接云服务器连接不上 【1.1】解决方法一 【1.2】解决方法二 【1】使用xshell连接云服务器连接不上 Centos7使用xshell连接提示"ssh服务器拒绝了密码 请再试一次"。 问题如图所示&#xff0c;新安装了一台Centos7服务器&#xff0c;使用ssh连…

200行代码实现canvas九宫格密码锁

现在很多app&#xff0c;在一些隐私页面&#xff0c;往往都会加入二次验证&#xff0c;例如银行app、支付宝理财和我的页面&#xff0c;一般会有「九宫格密码」和指纹密码。 今天我们用canvas来写一个九宫格手势密码锁&#xff0c;大概就是下面这样。 思路 准备一个正方形画布…