小球自由落体反弹js
时间: 2023-12-07 17:05:36 浏览: 39
以下是小球自由落体反弹的JavaScript代码实现:
```javascript
// 获取画布和上下文
var canvas = document.getElementById("myCanvas");
var ctx = canvas.getContext("2d");
// 定义小球的属性
var x = canvas.width / 2;
var y = canvas.height - 30;
var ballRadius = 10;
var dx = 2;
var dy = -2;
// 绘制小球
function drawBall() {
ctx.beginPath();
ctx.arc(x, y, ballRadius, 0, Math.PI * 2);
ctx.fillStyle = "#0095DD";
ctx.fill();
ctx.closePath();
}
// 绘制画布
function draw() {
ctx.clearRect(0, 0, canvas.width, canvas.height);
drawBall();
// 碰撞检测
if (x + dx > canvas.width - ballRadius || x + dx < ballRadius) {
dx = -dx;
}
if (y + dy > canvas.height - ballRadius || y + dy < ballRadius) {
dy = -dy;
}
// 更新小球位置
x += dx;
y += dy;
}
// 定时刷新画布
setInterval(draw, 10);
```
以上代码实现了一个小球自由落体反弹的动画效果,具体实现方式是通过定时刷新画布来更新小球的位置,同时通过碰撞检测来实现小球的反弹效果。