移动端开心刮刮乐HTML5特效

<!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>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值