《JS原理、方法与实践》- canvas游戏

作者 : 开心源码 本文共1826个字,预计阅读时间需要5分钟 发布时间: 2022-05-14 共155人阅读

游戏其实就是在动画的基础上增加了控制,也就是增加键盘和鼠标的事件监听。增加事件的方法前面已经学过,增加键盘事件和普通节点对象的键盘事件相同,只是canvas中的鼠标事件需要做少量解决。

鼠标事件

在鼠标事件中,鼠标指针所处位置的坐标是非常重要的属性,鼠标事件中只能获取相对于屏幕左上角和相对浏览器文档左上角的坐标,而canvas中使用的是自己的坐标系,因而需要将获取的坐标转换为canvas中的坐标。在转换之前,首先获取canvas在浏览器中的位置,可以通过getBoundingClientRect方法获取。例如下面的方法将浏览器中的坐标转换为canvas中的坐标:

        function convertToCanvas(canvas, x, y){            var canvasElement = canvas.getBoundingClientRect();            return {                x: (x - canvasElement.left) * (canvas.width / canvasElement.width),                y: (y - canvasElement.top) * (canvas.height / canvasElement.height)            };        }

转换逻辑:

  • 先使用鼠标事件中相对于浏览器文档的坐标减去canvas左上角的坐标
  • 而后进行相应的缩放

示例:
点中圆中5分,没点中扣3分。

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <meta name="viewport" content="width=device-width, initial-scale=1.0">    <title>Document</title></head><body>    <canvas id='c2d' width="300" height="300">浏览器不支持canvas</canvas>    <script>        const canvas = document.getElementById('c2d');                function convertToCanvas(canvas, x, y){            var canvasElement = canvas.getBoundingClientRect();            return {                x: (x - canvasElement.left) * (canvas.width / canvasElement.width),                y: (y - canvasElement.top) * (canvas.height / canvasElement.height)            };        }                if (canvas.getContext) {            let ctx = canvas.getContext('2d');            let path, scoreArea = {w:300, h:50};            function drawObj(){                const offsetX = 0, offsetY = scoreArea.h;                                ctx.save();                ctx.clearRect(offsetX, offsetY, 300,300);                const r = 30;                const x = r + offsetX + Math.round(Math.random() * (canvas.width - 2 * r - offsetX));                const y = r + offsetY + Math.round(Math.random() * (canvas.height - 2 * r -offsetY));                path = new Path2D();                path.arc(x,y,r,0,2*Math.PI);                ctx.stroke(path);            }            window.setInterval(drawObj, 2000);            let score = 3;            function drawScore(isTrue){                score += isTrue ? 5 : -3;                ctx.save();                ctx.fillStyle = 'red';                ctx.clearRect(0,0,scoreArea.w, scoreArea.h);                ctx.fillText('得分:' + score, 30,30);                ctx.restore();            }            drawScore(false);            canvas.onclick = function(event){                const p = convertToCanvas(canvas, event.pageX, event.pageY);                drawScore(ctx.isPointInPath(path,p.x,p.y));            }        }    </script></body></html>

说明
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是摆设,本站源码仅提供给会员学习使用!
7. 如遇到加密压缩包,请使用360解压,如遇到无法解压的请联系管理员
开心源码网 » 《JS原理、方法与实践》- canvas游戏

发表回复