physics/projects/projectile/index.js

66 lines
1 KiB
JavaScript
Raw Normal View History

2021-10-03 18:41:52 +02:00
2021-10-03 21:34:25 +02:00
let t=0;
let v0=50
let x0=0
let y0=50
let g=9.81
2021-10-03 18:41:52 +02:00
let projectile= function (node){
node.setup = function() {
node.createCanvas(width, height);
};
2021-10-03 21:34:25 +02:00
let width=800
let height=300
2021-10-03 18:41:52 +02:00
let dots=[]
function x(t) {
return x0+v0*t
}
function y(t) {
return height - (-1/2 * g * t**2 + v0 * t + y0)
}
node.draw = function() {
node.background(50);
2021-10-03 21:34:25 +02:00
node.noStroke();
dots.forEach((elt)=>{node.ellipse(elt[0],elt[1],5,5);})
2021-10-03 18:41:52 +02:00
node.ellipse(x(t),y(t),20,20);
dots.push([x(t),y(t)])
2021-10-03 21:34:25 +02:00
if(t>50 || y(t)>height){
2021-10-03 18:41:52 +02:00
node.noLoop()
}
2021-10-03 21:34:25 +02:00
t+=0.06
2021-10-03 18:41:52 +02:00
};
};
2021-10-03 21:34:25 +02:00
refresh=function(){
t=0
x0=parseFloat(app.x0)
y0=parseFloat(app.y0)
v0=parseFloat(app.v0)
g=parseFloat(app.g)
console.log(app.x0)
p5Load()
}
project_init=function(){
app = new Vue({
el: '#app',
data :{
x0:x0,
y0:y0,
v0:v0,
g:g
}
})
p5Load()
}