如何用canvas实现刮刮乐自助

简介: 如何用canvas实现刮刮乐自助

精心布局

准备一个canvas元素, 在准备一个显示中奖结果的盒子,让两个元素叠在一起,刮卡的时候,再让ggl盒子里面的内容显示出来


<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        #c1 {
            position: absolute;
            top: 0;
            left: 0;
            z-index: 10
        }
        .ggl {
            position: absolute;
            top: 0;
            left: 0;
            background: gray;
            width: 600px;
            height: 400px;
            line-height: 400px;
            font-size: 50px;
            font-weight: 700;
            text-align: center;
        }
    </style>
</head>
<body>
    <canvas id="c1" width="600" height="400"></canvas>
    <div class="ggl">谢谢惠顾</div>
</body>
</html>


获取canvas元素,并创建图片对象,将卡片渲染出来


<script>
        /**
         * @type {HTMLCanvasElement}
         */
        const c1 = document.querySelector('#c1')
        const ggl = document.querySelector('.ggl')
        const ctx = c1.getContext('2d')
        const img = new Image()
        img.src = './ggl.jpg'
        img.onload = function () {
            ctx.drawImage(img, 0, 0, 600, 400)
        }
    </script>


执行计划

我们再点击鼠标并且移动时才可以刮刮,通过鼠标对象,创建一个圆,向外辐射,从而模拟刮卡的过程


通过canvas图像合成 globalCompositeOperation 为其设置destination-out, 将背后的中奖结果展示出来


let isDraw = false
        c1.onmousedown = function () {
            isDraw = true
        }
        c1.onmouseup = function () {
            isDraw = false
        }
        c1.onmousemove = function (e) {
            let x = e.pageX
            let y = e.pageY
            if (isDraw) {
                ctx.globalCompositeOperation = 'destination-out'
                ctx.arc(x, y, 30, 0, Math.PI * 2)
                ctx.fill()
            }
        }


通过这样,我们的刮刮乐就制作完毕了。


image.png

QQ录屏20230712180427


如果再添点乐趣,可以这样


let random = Math.random()
        if (random < 0.2) {
            ggl.innerHTML = '恭喜您中了iphone13 Pro'
        }

image.png

相关文章
|
Android开发 容器
Android UI设计: 什么是View和ViewGroup?
Android UI设计: 什么是View和ViewGroup?
534 0
|
消息中间件 监控 算法
深入理解Linux进程管理与优化:原理、调度和资源控制详解
深入理解Linux进程管理与优化:原理、调度和资源控制详解
451 0
|
10月前
|
存储 安全 iOS开发
内存卡怎么格式化?6个格式化方法供你选
随着使用时间的增加,内存卡可能会因为数据积累、兼容性或是文件系统损坏等原因需要进行格式化。那么怎样正确格式化内存卡呢?格式化内存卡的时候需要注意什么呢?本文会给大家提供详细的步骤,帮助大家轻松完成格式化内存卡的操作。
|
缓存 前端开发 JavaScript
Webpack 4 和 Webpack 5 区别?
【10月更文挑战第23天】随着时间的推移,Webpack 可能会继续发展和演进,未来的版本可能会带来更多的新特性和改进。保持对技术发展的关注和学习,将有助于我们更好地应对不断变化的前端开发环境。
|
10月前
|
监控 安全 算法
龙蜥衍生版KeyarchOS国密应用、eBPF安全技术实践介绍|龙蜥大讲堂107期
龙蜥衍生版KeyarchOS国密应用及eBPF安全技术实践介绍。本次分享由浪潮信息的霍文和甄鹏主讲,涵盖全栈国密、国密密钥证书、国密通信等内容,并介绍了基于eBPF技术的新一代零侵入安全防御组件KSecure。通过实际案例展示了敏感信息传输加密、虚拟机热迁移等应用场景,以及如何利用eBPF实现进程注入检测等安全功能。该技术方案有效提升了操作系统的安全性与合规性,为服务器提供了强大的安全保障。
264 12
龙蜥衍生版KeyarchOS国密应用、eBPF安全技术实践介绍|龙蜥大讲堂107期
|
缓存 监控 网络协议
移动端常见白屏问题优化之网络优化篇
本文将要分享的是得物技术团队针对移动端最常见的图片加载导致的端侧白屏问题,而进行的的移动网络方向的技术优化实践,希望能带给你启发。
185 2
移动端常见白屏问题优化之网络优化篇
|
前端开发 应用服务中间件 nginx
前端服务器部署方式
【8月更文挑战第25天】前端服务器部署方式
638 1
|
机器学习/深度学习 PyTorch 算法框架/工具
自定义 DataLoader 设计:满足特定需求的实现方案
【8月更文第29天】在深度学习中,数据加载和预处理是训练模型前的重要步骤。PyTorch 提供了 `DataLoader` 类来帮助用户高效地从数据集中加载数据。然而,在某些情况下,标准的 `DataLoader` 无法满足特定的需求,例如处理非结构化数据、进行复杂的预处理操作或是支持特定的数据格式等。这时就需要我们根据自己的需求来自定义 DataLoader。
326 1
|
11月前
|
网络架构
一文带你了解 Next Route 使用
一文带你了解 Next Route 使用
210 1
|
数据采集 自然语言处理 搜索推荐
通义千问赋能CACA指南:构建智慧肿瘤诊疗新生态
本文探讨了如何利用阿里云通义千问大模型,结合中国抗癌协会(CACA)编撰的《中国肿瘤整合诊治指南》,打造新一代智能化临床决策支持系统。该系统通过分层架构设计,实现智能问答、临床决策支持和患者管理等功能,显著提升了医生的工作效率和治疗方案的科学性。
624 1