重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
作业成果展示
创新互联主要业务有网站营销策划、做网站、成都网站设计、微信公众号开发、重庆小程序开发公司、HTML5建站、程序开发等业务。一次合作终身朋友,是我们奉行的宗旨;我们不仅仅把客户当客户,还把客户视为我们的合作伙伴,在开展业务的过程中,公司还积累了丰富的行业经验、成都全网营销推广资源和合作伙伴关系资源,并逐渐建立起规范的客户服务和保障体系。
实验原理
主要是要实现小正方形的上下来回运动,并且每个小正方形的跳动有一定的时间差视觉上要呈现依次跳动的感觉。
本来我想用一个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码绘“跳动的小正方形”的实现代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对创新互联网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!