canvas绘制动态小球

canvas绘制动态小球

<!DOCTYPE html>
<html>
<head>
	<title>canvas绘制动态小球</title>
	<script src="https://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script>
	<style type="text/css">
		.inline {
			display: list-item;
		}
		body {
			margin: 0
		}
		canvas {
			border: 1px solid #999;
		}

	</style>

	<script type="text/javascript">
		var a;
		$(function() {
			a = $("#select")
			console.log(a)
		})
		function change() {
			console.log(a.val())
		}
	</script>
</head>
<body>
	<canvas id="mycanvas"></canvas>
	<script type="text/javascript">
		var canvas = document.getElementById('mycanvas')
		var ctx = canvas.getContext('2d')
		canvas.width = document.documentElement.clientWidth
		canvas.height = document.documentElement.clientHeight

		var ballArr = []

		function Ball(x, y, r, color) {
			this.x = x
			this.y = y
			this.r = r
			this.color = color
			this.dx = parseInt(Math.random() * 10) - 5 
			this.dy = parseInt(Math.random() * 10) - 5
			if(ballArr)ballArr.push(this)
		}
		Ball.prototype.update = function() {
			this.x += this.dx
			this.y += this.dy
			this.r -= 1
		}
		Ball.prototype.render = function() {
			ctx.beginPath()
			ctx.arc(this.x, this.y, this.r, 0, Math.PI * 2, true)
			ctx.fillStyle = this.color
			ctx.fill()
		}
		function getColor() {
			var color = '#'
			var arrStr = "1,2,3,4,5,6,7,8,9,A,B,C,D,E,F"
			var arr = arrStr.split(',')
			for (var i = 0; i < 6; i++) {
				color += arr[parseInt(Math.random() * arr.length)]
			}
			return color
		}
		setInterval(() => {
			ctx.clearRect(0, 0, canvas.width, canvas.height)
			console.log(ballArr.length)
			for (var i = 0; i < ballArr.length; i++) {
				ballArr[i].render()
				ballArr[i].update()
				if(ballArr[i].r < 0) {
					ballArr.splice(i, 1)
				}
			}
		}, 30)
		document.addEventListener('mousemove', function(e) {
			new Ball(e.offsetX, e.offsetY, 30, getColor())
		})
	</script>
</body>
</html>```

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值