作业成果展示
实验原理
主要是要实现小正方形的上下来回运动,并且每个小正方形的跳动有一定的时间差视觉上要呈现依次跳动的感觉。
本来我想用一个if语句来实现这个功能!但是想了很久没想到正确的代码……后来经同学提醒用了sin函数!真的很好用!
var y1=posY+30sin(t); var y2=posY+28sin(t-1); var y3=posY+26sin(t-2); var y4=posY+24sin(t-3); var y5=posY+22sin(t-4); var y6=posY+20sin(t-5);
这种sin函数不但能实现依照时间上下做简谐运动,而且只需要改变sin前面的振幅和里面的参数就能够做到小正方形的依次跳动。
小正方形的圆角变化也是用了sin函数,不过因为rect后面控制角的参数是不接受负数的所以用了var b=abs(a)取绝对值。
代码
let posY; function setup() { createCanvas(630, 500);//创建画布 noStroke();//不给物体描边 frameRate(60);//帧率设为60 } function draw() { background(220);//画布的背景颜色 //为小正方形圆角变化做准备 var t=millis()/400; posY=height*0.46; var a=20*sin(t*0.7); var b=abs(a);//取绝对值 //为小正方形上下运动做准备 var y1=posY+30*sin(t); var y2=posY+28*sin(t-1); var y3=posY+26*sin(t-2); var y4=posY+24*sin(t-3); var y5=posY+22*sin(t-4); var y6=posY+20*sin(t-5); var y11=posY+30*cos(t); var y22=posY+28*cos(t-1); var y33=posY+26*cos(t-2); var y44=posY+24*cos(t-3); var y55=posY+22*cos(t-4); var y66=posY+20*cos(t-5); //画小正方形 fill(211); rect(10, y1, 15, 15,b); fill(192) rect(30, y2, 20,20,b); fill(169) rect(60, y3, 30,30,b); fill(128) rect(100, y4, 40,40,b); fill(105) rect(150, y5, 50,50,b); fill(0) rect(210, y6, 60,60,b); fill(r, g, b, 127)//每次点击一下最中间的小正方形都会改变它的颜色 rect(280,posY ,70,70,b); fill(0) rect(360, y66, 60,60,b); fill(105) rect(430, y55, 50,50,b); fill(128) rect(490, y44, 40,40,b); fill(169) rect(540, y33, 30,30,b); fill(192) rect(580, y22, 20,20,b); fill(211); rect(605, y11, 15, 15,b); } //关于鼠标点击做出响应的函数 function mouseClicked() { let d = dist(mouseX, mouseY, 360, 200); if (d < 100) { // Pick new random color values r = random(255); g = random(255); b = random(255); }}
总结
以上所述是小编给大家介绍的p5.js码绘“跳动的小正方形”的实现代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“p5.js码绘“跳动的小正方形”的实现代码”评论...
更新动态
2024年11月13日
2024年11月13日
- 群星《2023好听新歌28》十倍音质 U盘音乐[WAV分轨][1G]
- faker拿了几个全球冠军 faker全球冠军数量介绍
- 英雄联盟faker拿了多少个冠军 Faker获得冠军数量介绍
- 英雄联盟全华班有夺冠过吗 英雄联盟全华班有没有夺过冠
- ChadCrouch-BartonCreekSoundwalk(2024)[24Bit-96kHz]FLAC
- BestAudiophileVoices4(2005)[FLAC]
- 常月《中国红》[DTS-WAV分轨]
- 国外《CS》选手抱怨上海major外设:桌子不能调节
- 美女推主COS合集图赏
- FS社母公司角川宣布:旗下共有26款游戏积极开发中!
- 黄莺莺.1984-炎夏的梦(2004环球复黑王)【宝丽金】【WAV+CUE】
- 黄雅莉.2009-雅莉不怕【福茂】【FLAC分轨】
- 张宇.1997-温古知新一个人的天荒地老【EMI百代】【WAV+CUE】
- 「灵与火的织卷」前瞻讨论开启 参与赢原石
- 【原神手游】原神基尼奇生日快乐