<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">
<title>移动端开心刮刮乐</title>
<style>
* {
margin: 0;
padding: 0;
box-sizing: border-box;
touch-action: manipulation;
}
body {
font-family: "Microsoft YaHei", sans-serif;
background: #FFD700;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
height: 100vh;
overflow: hidden;
padding: 15px;
}
.container {
position: relative;
width: 100%;
max-width: 400px;
height: 200px;
border-radius: 15px;
overflow: hidden;
box-shadow: 0 10px 20px rgba(0, 0, 0, 0.2);
}
.prize {
position: absolute;
width: 100%;
height: 100%;
background: linear-gradient(135deg, #FF416C, #FF4B2B);
display: flex;
justify-content: center;
align-items: center;
font-size: 24px;
color: white;
font-weight: bold;
z-index: 1;
}
.scratch-area {
position: absolute;
width: 100%;
height: 100%;
background: #888;
z-index: 2;
cursor: url(''), auto;
}
.result {
display: none;
position: absolute;
width: 100%;
height: 100%;
background: transparent;
z-index: 3;
justify-content: center;
align-items: center;
flex-direction: column;
color: #FFD700;
font-weight: bold;
text-align: center;
}
.result h2 {
font-size: 28px;
margin-bottom: 10px;
text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5);
}
.result p {
font-size: 18px;
margin-bottom: 15px;
}
.btn-restart {
padding: 8px 20px;
background: #FFD700;
color: #FF4B2B;
border: none;
border-radius: 20px;
font-weight: bold;
font-size: 16px;
cursor: pointer;
box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}
.credit {
margin-top: 20px;
color: #333;
font-size: 12px;
text-align: center;
}
</style>
</head>
<body>
<h1 style="color: #FF4B2B; margin-bottom: 20px;">开心刮刮乐</h1>
<div class="container">
<div class="prize">刮开涂层查看奖品</div>
<canvas class="scratch-area" id="scratchCanvas"></canvas>
<div class="result" id="result">
<h2 id="prizeText">恭喜您!</h2>
<p id="prizeDesc">获得一等奖!</p>
<button class="btn-restart" οnclick="restartScratch()">再玩一次</button>
</div>
</div>
<div class="credit">游戏提供:www.5cq.website</div>
<script>
// 奖品配置
const prizes = [
{ name: "一等奖", desc: "获得100元现金红包!", color: "#FF0000", bg: "#FFD700", chance: 5 },
{ name: "二等奖", desc: "获得50元优惠券!", color: "#FF4500", bg: "#FFA500", chance: 15 },
{ name: "三等奖", desc: "获得20元优惠券!", color: "#4169E1", bg: "#87CEEB", chance: 30 },
{ name: "参与奖", desc: "谢谢参与!", color: "#2E8B57", bg: "#98FB98", chance: 50 }
];
// 初始化变量
const canvas = document.getElementById('scratchCanvas');
const ctx = canvas.getContext('2d');
const resultDiv = document.getElementById('result');
const prizeText = document.getElementById('prizeText');
const prizeDesc = document.getElementById('prizeDesc');
let isDrawing = false;
let currentPrize = null;
// 设置画布大小
function resizeCanvas() {
const container = document.querySelector('.container');
canvas.width = container.offsetWidth;
canvas.height = container.offsetHeight;
// 初始化刮刮卡涂层
initScratchLayer();
}
// 初始化刮刮卡涂层
function initScratchLayer() {
ctx.fillStyle = '#888';
ctx.fillRect(0, 0, canvas.width, canvas.height);
// 添加纹理
ctx.fillStyle = '#999';
for (let i = 0; i < 100; i++) {
const x = Math.random() * canvas.width;
const y = Math.random() * canvas.height;
const size = Math.random() * 3 + 1;
ctx.beginPath();
ctx.arc(x, y, size, 0, Math.PI * 2);
ctx.fill();
}
// 添加文字
ctx.fillStyle = '#666';
ctx.font = 'bold 16px Arial';
ctx.textAlign = 'center';
ctx.fillText('刮开此处查看奖品', canvas.width / 2, canvas.height / 2);
}
// 随机选择奖品
function selectPrize() {
const totalChance = prizes.reduce((sum, prize) => sum + prize.chance, 0);
let random = Math.random() * totalChance;
let accumulated = 0;
for (const prize of prizes) {
accumulated += prize.chance;
if (random <= accumulated) {
return prize;
}
}
return prizes[prizes.length - 1]; // 默认返回最后一个
}
// 开始刮卡
function startScratching(e) {
isDrawing = true;
// 第一次触摸时确定奖品
if (!currentPrize) {
currentPrize = selectPrize();
prizeText.textContent = currentPrize.name;
prizeText.style.color = currentPrize.color;
prizeDesc.textContent = currentPrize.desc;
}
draw(e);
}
// 结束刮卡
function endScratching() {
isDrawing = false;
ctx.beginPath();
// 检查刮开面积是否超过50%
checkScratchedArea();
}
// 绘制刮痕
function draw(e) {
if (!isDrawing) return;
// 获取触摸位置
let x, y;
if (e.type.includes('touch')) {
const rect = canvas.getBoundingClientRect();
x = e.touches[0].clientX - rect.left;
y = e.touches[0].clientY - rect.top;
} else {
x = e.offsetX;
y = e.offsetY;
}
// 绘制圆形擦除区域
ctx.globalCompositeOperation = 'destination-out';
ctx.beginPath();
ctx.arc(x, y, 20, 0, Math.PI * 2);
ctx.fill();
// 检查刮开面积
checkScratchedArea();
}
// 检查刮开面积
function checkScratchedArea() {
// 获取图像数据
const imageData = ctx.getImageData(0, 0, canvas.width, canvas.height);
const pixels = imageData.data;
let transparentPixels = 0;
// 计算透明像素数量
for (let i = 3; i < pixels.length; i += 4) {
if (pixels[i] === 0) {
transparentPixels++;
}
}
// 计算透明像素比例
const totalPixels = canvas.width * canvas.height;
const ratio = transparentPixels / totalPixels;
// 如果刮开面积超过50%,显示结果
if (ratio > 0.5) {
showResult();
}
}
// 显示结果
function showResult() {
resultDiv.style.display = 'flex';
resultDiv.style.backgroundColor = currentPrize.bg;
}
// 重新开始
function restartScratch() {
currentPrize = null;
resultDiv.style.display = 'none';
initScratchLayer();
}
// 事件监听
canvas.addEventListener('mousedown', startScratching);
canvas.addEventListener('mousemove', draw);
canvas.addEventListener('mouseup', endScratching);
canvas.addEventListener('mouseleave', endScratching);
canvas.addEventListener('touchstart', startScratching);
canvas.addEventListener('touchmove', draw);
canvas.addEventListener('touchend', endScratching);
window.addEventListener('resize', resizeCanvas);
// 初始化
resizeCanvas();
</script>
</body>
</html>