热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

打砖块小游戏php程序,利用原生js实现html5打砖块小游戏(代码示例)

本篇文章给大家通过代码示例介绍一下利用原生js实现html5打砖块小游戏的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。前言PS

本篇文章给大家通过代码示例介绍一下利用原生js实现html5打砖块小游戏的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

前言

PS:本次项目中使用了大量 es6 语法,故对于 es6 语法不太熟悉的小伙伴最好能先了解一些基本的原理再继续阅读。

首先,先说明一下做这个系列的目的:其实主要源于博主希望熟练使用 canvas 的相关 api ,同时对小游戏的实现逻辑比较感兴趣,所以希望通过这一系列的小游戏来提升自身编程能力;关于 es6 语法,个人认为以后 es6 语法会越来越普及,所以算是提前熟悉语法使用技巧。小游戏的实现逻辑上可能并不完善,也许会有一些 bug ,但是毕竟只是为了提升编程能力与技巧,希望大家不要太较真

作为第一次分享,我选择打砖块这个逻辑不算太复杂的小游戏。同时,为了接近真实游戏效果,在游戏中也添加了关卡,砖块血量,以及物理碰撞模型的简略实现。其实关注游戏实现逻辑就好了

线上演示地址:http://demo.jb51.net/js/2018/h5-game-blockBreaker

github地址:https://github.com/yangyunhe369/h5-game-blockBreaker

本地下载地址:http://xiazai.jb51.net/201801/yuanma/h5-game-blockBreaker(jb51.net).rar

ps:github地址和本地下载有代码演示,以及源码可供参考,线上演示地址可供预览

先上一个游戏完成后的截图

0560a632c9ae1537b1239a5fcba468fa.png

游戏工程目录如下.

├─ index.html // 首页html

├─ css // css样式资源文件

├─ images // 图片资源文件

└─ js

├─ common.js // 公共js方法

├─ game.js // 游戏主要运行逻辑

└─ scene.js // 游戏场景相关类

游戏实现逻辑

这里对游戏中需要绘制的挡板、小球、砖块、计分板都进行了实例化,并将游戏主要运行逻辑单独进行实例化

挡板 Paddleclass Paddle {

constructor (_main) {

let p = {

x: _main.paddle_x, // x 轴坐标

y: _main.paddle_y, // y 轴坐标

w: 102, // 图片宽度

h: 22, // 图片高度

speed: 10, // x轴移动速度

ballSpeedMax: 8, // 小球反弹速度最大值

image: imageFromPath(allImg.paddle), // 引入图片对象

isLeftMove: true, // 能否左移

isRightMove: true, // 能否右移

}

Object.assign(this, p)

}

// 向左移动

moveLeft () {

...

}

// 向右移动

moveRight () {

...

}

// 小球、挡板碰撞检测

collide (ball) {

...

}

// 计算小球、挡板碰撞后x轴速度值

collideRange (ball) {

...

}

}

挡板类:主要会定义其坐标位置、图片大小、x 轴位移速度、对小球反弹速度的控制等,再根据不同按键响应 moveLeft 和 moveRight 移动事件,collide 方法检测小球与挡板是否碰撞,并返回布尔值

小球 Ballclass Ball {

constructor (_main) {

let b = {

x: _main.ball_x, // x 轴坐标

y: _main.ball_y, // y 轴坐标

w: 18, // 图片宽度

h: 18, // 图片高度

speedX: 1, // x 轴速度

speedY: 5, // y 轴速度

image: imageFromPath(allImg.ball), // 图片对象

fired: false, // 是否运动,默认静止不动

}

Object.assign(this, b)

}

move (game) {

...

}

}

小球类:其大部分属性与挡板类似,主要通过 move 方法控制小球运动轨迹

砖块 Blockclass Block {

constructor (x, y, life = 1) {

let bk = {

x: x, // x 轴坐标

y: y, // y 轴坐标

w: 50, // 图片宽度

h: 20, // 图片高度

image: life == 1 ? imageFromPath(allImg.block1) : imageFromPath(allImg.block2), // 图片对象

life: life, // 生命值

alive: true, // 是否存活

}

Object.assign(this, bk)

}

// 消除砖块

kill () {

...

}

// 小球、砖块碰撞检测

collide (ball) {

...

}

// 计算小球、砖块碰撞后x轴速度方向

collideBlockHorn (ball) {

...

}

}

砖块类:会有两个属性不同,分别是 life 和 是否存活。然后,在小球和砖块撞击时,调用 kill 方法扣除当前砖块血量,当血量为0时,清除砖块。collide 方法检测小球与砖块是否碰撞,并返回布尔值

计分板 Scoreclass Score {

constructor (_main) {

let s = {

x: _main.score_x, // x 轴坐标

y: _main.score_y, // y 轴坐标

text: '分数:', // 文本分数

textLv: '关卡:', // 关卡文本

score: 200, // 每个砖块对应分数

allScore: 0, // 总分

blockList: _main.blockList, // 砖块对象集合

blockListLen: _main.blockList.length, // 砖块总数量

lv: _main.LV, // 当前关卡

}

Object.assign(this, s)

}

// 计算总分

computeScore () {

...

}

}

分数类:会记录当前分数、关卡数,其中 computeScore 方法会在小球碰撞砖块且砖块血量为0时调用,并累加总分

场景 Sceneclass Scene {

constructor (lv) {

let s = {

lv: lv, // 游戏难度级别

canvas: document.getElementById("canvas"), // canvas 对象

blockList: [], // 砖块坐标集合

}

Object.assign(this, s)

}

// 实例化所有砖块对象

initBlockList () {

...

}

// 创建砖块坐标二维数组,并生成不同关卡

creatBlockList () {

...

}

}

场景类:主要是根据游戏难度级别,绘制不同关卡及砖块集合(目前只生成了三个关卡)。其中 creatBlockList 方法先生成所有砖块的二维坐标数组,再调用 initBlockList 方法进行所有砖块的实例化

游戏主逻辑 Gameclass Game {

constructor (fps = 60) {

let g = {

actions: {}, // 记录按键动作

keydowns: {}, // 记录按键 keycode

state: 1, // 游戏状态值,初始默认为1

state_START: 1, // 开始游戏

state_RUNNING: 2, // 游戏开始运行

state_STOP: 3, // 暂停游戏

state_GAMEOVER: 4, // 游戏结束

state_UPDATE: 5, // 游戏通关

canvas: document.getElementById("canvas"), // canvas 元素

context: document.getElementById("canvas").getContext("2d"), // canvas 画布

timer: null, // 轮询定时器

fps: fps, // 动画帧数,默认60

}

Object.assign(this, g)

}

...

}

游戏核心类:这里包括游戏主要运行逻辑,包括但不限于以下几点绘制游戏整个场景

调用定时器逐帧绘制动画

游戏通关及游戏结束判定

绑定按钮事件

边界检测处理函数

碰撞检测处理函数

入口函数 _mainlet _main = {

LV: 1, // 初始关卡

MAXLV: 3, // 最终关卡

scene: null, // 场景对象

blockList: null, // 所有砖块对象集合

ball: null, // 小球对象

paddle: null, // 挡板对象

score: null, // 计分板对象

ball_x: 491, // 小球默认 x 轴坐标

ball_y: 432, // 小球默认 y 轴坐标

paddle_x: 449, // 挡板默认 x 轴坐标

paddle_y: 450, // 挡板默认 y 轴坐标

score_x: 10, // 计分板默认 x 轴坐标

score_y: 30, // 计分板默认 y 轴坐标

fps: 60, // 游戏运行帧数

game: null, // 游戏主要逻辑对象

start: function () {

let self = this

/**

* 生成场景(根据游戏难度级别不同,生成不同关卡)

*/

self.scene = new Scene(self.LV)

// 实例化所有砖块对象集合

self.blockList = self.scene.initBlockList()

/**

* 小球

*/

self.ball = new Ball(self)

/**

* 挡板

*/

self.paddle = new Paddle(self)

/**

* 计分板

*/

self.score = new Score(self)

/**

* 游戏主要逻辑

*/

self.game = new Game(self.fps)

/**

* 游戏初始化

*/

self.game.init(self)

}

}

入口函数:实现了游戏中需要的所有类的实例化,并进行游戏的初始化



推荐阅读
  • 解决基于XML配置的MyBatis在Spring整合中出现“无效绑定语句(未找到):com.music.dao.MusicDao.findAll”问题的方法
    在将Spring与MyBatis进行整合时,作者遇到了“无效绑定语句(未找到):com.music.dao.MusicDao.findAll”的问题。该问题主要出现在使用XML文件配置DAO层的情况下,而注解方式配置则未出现类似问题。作者详细分析了两个配置文件之间的差异,并最终找到了解决方案。本文将详细介绍问题的原因及解决方法,帮助读者避免类似问题的发生。 ... [详细]
  • Node.js 教程第五讲:深入解析 EventEmitter(事件监听与发射机制)
    本文将深入探讨 Node.js 中的 EventEmitter 模块,详细介绍其在事件监听与发射机制中的应用。内容涵盖事件驱动的基本概念、如何在 Node.js 中注册和触发自定义事件,以及 EventEmitter 的核心 API 和使用方法。通过本教程,读者将能够全面理解并熟练运用 EventEmitter 进行高效的事件处理。 ... [详细]
  • 通过整合JavaFX与Swing,我们成功地将现有的Swing应用程序组件进行了现代化改造。此次升级不仅提升了用户界面的美观性和交互性,还确保了与原有Swing应用程序的无缝集成,为开发高质量的Java桌面应用提供了坚实的基础。 ... [详细]
  • 如何在Spark数据排序过程中有效避免内存溢出(OOM)问题
    本文深入探讨了在使用Spark进行数据排序时如何有效预防内存溢出(OOM)问题。通过具体的代码示例,详细阐述了优化策略和技术手段,为读者在实际工作中遇到类似问题提供了宝贵的参考和指导。 ... [详细]
  • 我正在使用 Ruby on Rails 构建个人网站。总体而言,RoR 是一个非常出色的工具,它提供了丰富的功能和灵活性,使得创建自定义页面变得既高效又便捷。通过利用其强大的框架和模块化设计,我可以轻松实现复杂的功能,同时保持代码的整洁和可维护性。此外,Rails 的社区支持也非常强大,为开发过程中遇到的问题提供了丰富的资源和解决方案。 ... [详细]
  • jQuery Flot 数据可视化插件:高效绘制图表的专业工具
    jQuery Flot 是一款高效的数据可视化插件,专为绘制各种图表而设计。该工具支持丰富的图表类型和自定义选项,适用于多种应用场景。用户可以通过其官方网站获取示例代码和下载资源,以便快速上手和使用。 ... [详细]
  • 如何使用 net.sf.extjwnl.data.Word 类及其代码示例详解 ... [详细]
  • 本文介绍了Android动画的基本概念及其主要类型。Android动画主要包括三种形式:视图动画(也称为补间动画或Tween动画),主要通过改变视图的属性来实现动态效果;帧动画,通过顺序播放一系列预定义的图像来模拟动画效果;以及属性动画,通过对对象的属性进行平滑过渡来创建更加复杂的动画效果。每种类型的动画都有其独特的应用场景和实现方式,开发者可以根据具体需求选择合适的动画类型。 ... [详细]
  • 池子比率:BSV 区块链上的去中心化金融应用——Uniswap 分析
    池子比率:BSV 区块链上的去中心化金融应用——Uniswap 分析 ... [详细]
  • BZOJ4240 Gym 102082G:贪心算法与树状数组的综合应用
    BZOJ4240 Gym 102082G 题目 "有趣的家庭菜园" 结合了贪心算法和树状数组的应用,旨在解决在有限时间和内存限制下高效处理复杂数据结构的问题。通过巧妙地运用贪心策略和树状数组,该题目能够在 10 秒的时间限制和 256MB 的内存限制内,有效处理大量输入数据,实现高性能的解决方案。提交次数为 756 次,成功解决次数为 349 次,体现了该题目的挑战性和实际应用价值。 ... [详细]
  • 在CentOS上部署和配置FreeSWITCH
    在CentOS系统上部署和配置FreeSWITCH的过程涉及多个步骤。本文详细介绍了从源代码安装FreeSWITCH的方法,包括必要的依赖项安装、编译和配置过程。此外,还提供了常见的配置选项和故障排除技巧,帮助用户顺利完成部署并确保系统的稳定运行。 ... [详细]
  • 本文深入解析了 Apache 配置文件 `httpd.conf` 和 `.htaccess` 的优化方法,探讨了如何通过合理配置提升服务器性能和安全性。文章详细介绍了这两个文件的关键参数及其作用,并提供了实际应用中的最佳实践,帮助读者更好地理解和运用 Apache 配置。 ... [详细]
  • 使用cpphttplib构建HTTP服务器以处理带有查询参数的URL请求 ... [详细]
  • 如何运用蒙特卡洛方法计算NPV:计算机专业毕业设计遇到难题怎么办?
    许多计算机科学专业的学生在大学期间都会遇到这样的困扰:课堂上教授的内容往往偏向理论,实际应用的知识点讲解得较为浅显和概括,导致在进行毕业设计时,如运用蒙特卡洛方法计算净现值(NPV)等复杂问题时感到无从下手。本文旨在探讨如何通过深入理解和实践蒙特卡洛模拟技术,解决这类计算难题,为学生的毕业设计提供实用指导。 ... [详细]
  • 在Unity中进行3D建模的全面指南,详细介绍了市场上三种主要的3D建模工具:Blender 3D、Maya和3ds Max。每种工具的特点、优势及其在Unity开发中的应用将被深入探讨,帮助开发者选择最适合自己的建模软件。 ... [详细]
author-avatar
李桂平2402851397
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有