绘制抽奖转盘 (CSS+JS)


Hello!这里是万物之恋,今天来教大家用css+js来简单绘制一个抽奖轮盘(不可转动)

HTML部分

	<div class="box">
		<h1>幸运大转盘</h1>
		<div class="giant-box">
			<div class="prize">
				<span class="prize-text">一等奖</span>
			</div>
			<div class="prize">
				<span class="prize-text">二等奖</span>
			</div>
			<div class="prize">
				<span class="prize-text">三等奖</span>
			</div>
			<div class="prize">
				<span class
  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
好的,下面是一个基于HTMLCSSJS实现带有转盘的抽奖小程序的示例代码。 首先,我们需要在HTML中创建一个canvas元素,作为转盘的容器。 ```html <canvas id="canvas" width="400" height="400"></canvas> ``` 接下来,我们需要先在JS中定义一些转盘相关的变量和常量。 ```javascript var canvas = document.getElementById("canvas"); var ctx = canvas.getContext("2d"); // 转盘的中心点坐标 var x = canvas.width / 2; var y = canvas.height / 2; // 转盘半径 var r = x; // 转盘的扇形数量 var sectorCount = 6; // 每个扇形的角度 var sectorAngle = Math.PI * 2 / sectorCount; // 转盘的旋转角度 var rotateAngle = 0; // 奖品名称数组 var prizeTexts = ["奖品1", "奖品2", "奖品3", "奖品4", "奖品5", "奖品6"]; ``` 然后,我们可以编写一个函数来绘制转盘的扇形和文本。 ```javascript function drawSector(startAngle, endAngle, color, text) { // 绘制扇形 ctx.beginPath(); ctx.moveTo(x, y); ctx.arc(x, y, r, startAngle, endAngle); ctx.closePath(); ctx.fillStyle = color; ctx.fill(); // 绘制文本 ctx.save(); ctx.translate(x, y); ctx.rotate(startAngle + (endAngle - startAngle) / 2); ctx.fillStyle = "#fff"; ctx.font = "bold 20px Arial"; ctx.fillText(text, r / 2, 0); ctx.restore(); } ``` 接下来,我们可以使用该函数来绘制转盘的扇形和文本。 ```javascript for (var i = 0; i < sectorCount; i++) { var startAngle = i * sectorAngle - rotateAngle; var endAngle = (i + 1) * sectorAngle - rotateAngle; var color = i % 2 == 0 ? "#f00" : "#0f0"; var text = prizeTexts[i]; drawSector(startAngle, endAngle, color, text); } ``` 现在,我们可以编写一个函数来旋转转盘。 ```javascript function rotate() { // 每次旋转增加的角度 var deltaAngle = Math.random() * 30 + 10; // 旋转角度增加 rotateAngle += deltaAngle; // 旋转到最近的扇形中心 var sectorIndex = Math.floor(rotateAngle / sectorAngle); rotateAngle = sectorIndex * sectorAngle; // 绘制转盘 ctx.clearRect(0, 0, canvas.width, canvas.height); for (var i = 0; i < sectorCount; i++) { var startAngle = i * sectorAngle - rotateAngle; var endAngle = (i + 1) * sectorAngle - rotateAngle; var color = i % 2 == 0 ? "#f00" : "#0f0"; var text = prizeTexts[i]; drawSector(startAngle, endAngle, color, text); } } ``` 最后,我们可以在HTML中添加一个按钮,当用户点击该按钮时,调用rotate()函数来旋转转盘。 ```html <button onclick="rotate()">开始抽奖</button> ``` 完整的代码如下: ```html <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>抽奖小程序</title> </head> <body> <canvas id="canvas" width="400" height="400"></canvas> <button onclick="rotate()">开始抽奖</button> <script> var canvas = document.getElementById("canvas"); var ctx = canvas.getContext("2d"); // 转盘的中心点坐标 var x = canvas.width / 2; var y = canvas.height / 2; // 转盘半径 var r = x; // 转盘的扇形数量 var sectorCount = 6; // 每个扇形的角度 var sectorAngle = Math.PI * 2 / sectorCount; // 转盘的旋转角度 var rotateAngle = 0; // 奖品名称数组 var prizeTexts = ["奖品1", "奖品2", "奖品3", "奖品4", "奖品5", "奖品6"]; function drawSector(startAngle, endAngle, color, text) { // 绘制扇形 ctx.beginPath(); ctx.moveTo(x, y); ctx.arc(x, y, r, startAngle, endAngle); ctx.closePath(); ctx.fillStyle = color; ctx.fill(); // 绘制文本 ctx.save(); ctx.translate(x, y); ctx.rotate(startAngle + (endAngle - startAngle) / 2); ctx.fillStyle = "#fff"; ctx.font = "bold 20px Arial"; ctx.fillText(text, r / 2, 0); ctx.restore(); } function rotate() { // 每次旋转增加的角度 var deltaAngle = Math.random() * 30 + 10; // 旋转角度增加 rotateAngle += deltaAngle; // 旋转到最近的扇形中心 var sectorIndex = Math.floor(rotateAngle / sectorAngle); rotateAngle = sectorIndex * sectorAngle; // 绘制转盘 ctx.clearRect(0, 0, canvas.width, canvas.height); for (var i = 0; i < sectorCount; i++) { var startAngle = i * sectorAngle - rotateAngle; var endAngle = (i + 1) * sectorAngle - rotateAngle; var color = i % 2 == 0 ? "#f00" : "#0f0"; var text = prizeTexts[i]; drawSector(startAngle, endAngle, color, text); } } </script> </body> </html> ``` 这样,我们就实现了一个简单的带有转盘的抽奖小程序。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值