html:canvas画布绘图简单入门-刮刮乐-4

简介: html:canvas画布绘图简单入门-刮刮乐-4

image.png

<style>
        body {
            margin: 0;
            padding: 0;
            height: 100vh;
            display: flex;
            align-items: center;
            justify-content: center;
        }
        .box-wrap {
            position: relative;
            width: 300px;
            height: 150px;
            border: 1px solid #eeeeee;
        }
        .box {
            position: absolute;
            width: 100%;
            height: 100%;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 25px;
            color: red;
            letter-spacing: 20px;
        }
        .canvas {
            position: absolute;
            width: 100%;
            height: 100%;
        }
    </style>
    <!-- 刮刮乐 -->
    <div class="box-wrap">
        <div class="box"
             id="text">谢谢惠顾</div>
        <canvas class="canvas"
                id="canvas"
                width="600"
                height="300"></canvas>
    </div>
    <script>
        let canvas = document.querySelector('#canvas');
        let text = document.querySelector('#text');
        let ctx = canvas.getContext('2d');
        let clientWidth = canvas.clientWidth;
        let clientHeight = canvas.clientHeight;
        let width = canvas.width
        let height = canvas.height
        // 缩放比例
        let widthScale = width / clientWidth;
        let heightScale = height / clientHeight;
        // 绘制背景图
        ctx.fillStyle = 'gray';
        ctx.fillRect(0, 0, width, height);
        ctx.save();
        // 绘制文字
        ctx.translate(width / 2, height / 2);
        ctx.textAlign = "center";
        ctx.textBaseline = "middle";
        ctx.font = "50px 微软雅黑"
        ctx.fillStyle = 'white';
        ctx.fillText('刮开查看', 0, 0);
        // ctx.fill();
        ctx.restore();
        // 监听鼠标事件
        let isDraw = false;
        canvas.onmousedown = function (e) {
            // console.log(e);
            isDraw = true;
        }
        canvas.onmouseup = function (e) {
            // console.log(e);
            isDraw = false;
        }
        canvas.onmousemove = function (e) {
            if (!isDraw) {
                return;
            }
            // console.log(e);
            // ctx.fillStyle = 'white';
            // 在源图像之外显示目标图像。只有源图像之外的目标图像部分会被显示,源图像是透明的
            ctx.globalCompositeOperation = 'destination-out'
            // console.log(e.offsetX, e.offsetY);
            ctx.arc(e.offsetX * widthScale, e.offsetY * heightScale, 30, 0, Math.PI / 180 * 360);
            ctx.fill();
        }
        // 奖品设置
        let list = [{
                title: '一等奖',
                probability: 0.1
            },
            {
                title: '二等奖',
                probability: 0.2
            },
            {
                title: '三等奖',
                probability: 0.3
            }
        ]
        let randomNum = Math.random();
        console.log(randomNum);
        let randomNumUpperBound = 0;
        for (let item of list) {
            randomNumUpperBound += item.probability
            if (randomNum < randomNumUpperBound) {
                text.innerText = item.title;
                break;
            }
        }
    </script>
相关文章
|
5天前
|
前端开发 JavaScript
Canvas三维变化背景动画HTML源码
Canvas三维变化背景动画HTML源码
19 5
|
2月前
|
XML 移动开发 前端开发
HTML5 SVG和canvas的性能探讨
HTML5 中的 SVG(可缩放矢量图形)和 Canvas(画布)分别用于网页图形绘制。SVG 基于矢量图形,使用 XML 描述,适合静态或少量动态内容(如图标、图表),易于编辑且保持高分辨率;Canvas 则基于位图,通过 JavaScript 绘制,更适合快速更新大量图形的场景(如游戏、动态动画),但在复杂图形计算时可能遇到性能瓶颈。总体而言,SVG 适用于静态和少量动态内容,而 Canvas 更适合高频率更新和性能要求高的场景。
|
2月前
|
移动开发 前端开发 JavaScript
HTML5 Canvas详解及应用
HTML5 Canvas 允许通过 JavaScript 在网页上动态绘制图形、动画等视觉内容。首先在 HTML 中定义 `&lt;canvas&gt;` 元素,并通过 JavaScript 获取画布上下文进行绘制。常见方法包括绘制矩形、路径、圆形和文本,以及处理图像和创建动画效果。适用于游戏开发、数据可视化、图像编辑和动态图形展示等多种应用场景。需要注意性能优化、无状态绘制及自行处理事件等问题。
|
2月前
|
前端开发 程序员
【前端web入门第二天】01 html语法实现列表与表格_合并单元格
本文介绍了HTML中的列表与表格的使用方法。列表包括无序列表(`&lt;ul&gt;`嵌套`&lt;li&gt;`)、有序列表(`&lt;ol&gt;`嵌套`&lt;li&gt;`)和定义列表(`&lt;dl&gt;`嵌套`&lt;dt&gt;`和`&lt;dd&gt;`)。
58 19
|
24天前
|
移动开发 前端开发 JavaScript
HTML入门(详细)
HTML入门(详细)
21 0
|
2月前
|
移动开发 前端开发 数据挖掘
用HTML5中的 画布(Canvas)在“圳品”信息系统网页上绘制显示饼图
用HTML5中的 画布(Canvas)在“圳品”信息系统网页上绘制显示饼图
|
2月前
|
前端开发
在 HTML canvas 绘制文本
在 HTML canvas 绘制文本
18 0
|
移动开发 前端开发 API
《HTML5 Canvas游戏开发实战》——3.4 小结
本节书摘来自华章计算机《HTML5 Canvas游戏开发实战》一书中的第3章,第3.4节,作者:张路斌著, 更多章节内容可以访问云栖社区“华章计算机”公众号查看。
976 0
|
移动开发 JavaScript 前端开发
《HTML5 Canvas游戏开发实战》——3.3 自定义画板
本节书摘来自华章计算机《HTML5 Canvas游戏开发实战》一书中的第3章,第3.3节,作者:张路斌著, 更多章节内容可以访问云栖社区“华章计算机”公众号查看。
1350 0
|
移动开发 JavaScript 前端开发
《HTML5 Canvas游戏开发实战》——3.2 图形的渲染
本节书摘来自华章计算机《HTML5 Canvas游戏开发实战》一书中的第3章,第3.2节,作者:张路斌著, 更多章节内容可以访问云栖社区“华章计算机”公众号查看。
1250 0