当前位置: 首页 > news >正文

基于vue编写的2048小游戏

  1. 具体干了件什么事情
    要实现如图所示的小游戏。2040游戏效果图
    规则是有16个格子,初始时会有两个格子上安放了两个数字,每次可以选择上下左右其中一个方向去滑动,每滑动一次,所有的数字方块都会往滑动的方向靠拢外,系统也会在空白的地方随即出现一个数字方块,相同数字的方块在靠拢,相撞时会相加。不断的叠加最终拼凑出8192这个数字就算成功。如果没有了空白的地方,也没有了相同的数字可以靠拢,相撞就游戏失败。

  2. 技术难点。
    2.1如图的展示,需要做到有滑动效果,相消的效果,
    2.2移动原理,还有判断数组相消,游戏结束,游戏胜利

  3. 怎么破解技术难点
    3.1滑动效果可是使用css的样式transform: translate(x,y);这个样式具有移动效果,我们可以把所以的数字块都定位到数字盘的最左上角,为了方便,我们把这个点称之为坐标原点(0,0),那么图中数字块64所在的坐标就为(3,3),由于我们使用的数字盘,和数字块都是矩形规则的,这里我先用的是写死的宽高从(0,0)–>(3,3)体现到样式上的距离就是(3*120px,3*120px),我定位这个数字块用的是transform: translate(3*120px,3*120px);由于我使用的是vue所以就更方便了,我只要准备好数据,这些重复性的工作就交个vue了,我使用了一个数组来装这个16个数字块,使用<span>标签来包裹每一个数字块,通过遍历数组来完成定位代码如下。
    数字块滑动
    3.2数字相消的效果可以使用es6的animate函数,我们其实只是做了个数字块在两毫秒内放大1.3倍然后又缩小回原始尺寸,这样给用户的感觉就是进行了合并,代码如下图所示。
    合并数字块时的样式改变
    3.3数字块移动,我们给数字块设置了如下数据结构{x:x, y:y, num:num, id:id, color:color},其实数字块的位置就是x,y的值,数字块的移动就相当于改变其x,y的值,我就拿一个方向作为例子,其他方向类似,我们按下上箭头,那么处理逻辑是先从y=0这排开始,也就是y=1这排有能够和y=0这排合并的合并,能下移的下移,然后是y=2,y=3,可是我们在新增数字块的时候x,y值是随机一个不存在的数字块坐标,这也就意味着数字中的不是有序的,我们需要首先根据y来进行排序,用排完序的和y-1排的进行比较处理,也就是说为了避免数组越界,我们排序的时候要去掉y=0这一层的,当检测到y-1为空时我们让当前数字块前进一步,并且继续和下一排做比较,如果检测到y-1不为空时,就看看他们的数值是否相同,相同则让下一排成2,本身数字块消失(这里面有个小坑,有的数字块可能面临两次操作,所以我额外记录了一个属性,用来判断当前数字块是否已经被处理过),涉及到的代码逻辑如下。
    排序
    移动函数
    3.4判断游戏是否成功,这个比较好实现,在每次移动的时候都去判断一次是不是有数字块的值达到了8192。
    3.5判读游戏是否失败,这个也是循环整个数组,首先判读数组是不是已经有16块了,其次判读还存不存在相邻的两个数字块的数字相同,如果满足16块且没有相同数字块相邻则判断游戏失败,关键代码如下。
    游戏结束

  4. 下篇博客需要完善的事项有
    4.1游戏数字块的移动采用矩阵方式
    4.2背景音乐的添加
    4.3游戏算法的优化

  5. 项目源码


http://www.taodudu.cc/news/show-6309739.html

相关文章:

  • 【physx/wasm】在physx中添加自定义接口并重新编译wasm
  • excel---常用操作
  • Lora训练Windows[笔记]
  • linux基础指令讲解(ls、pwd、cd、touch、mkdir)
  • InnoDB 事务处理机制
  • 启明云端ESP32 C3 模组WT32C3通过 MQTT 连接 AWS
  • 用Qt开发小游戏《愤怒的小鸟》
  • [效率提升]webstorm配置Prettier:代码自动格式,格式化时清除空行,修改使用代码模板
  • WebStorm+Vue-cli 配置alias 点击跳转无效问题
  • JavaScript葵花宝典(基础)
  • js Console 对象 - Kaiqisan
  • JS_01_变量_数据类型
  • vanilla_使用Vanilla JavaScript构建Cookie库
  • 笔记 - JavaScript - 超哥视频
  • JS知识点总结(全)
  • Vue.js + Vuex + TypeScript 实战项目开发与项目优化
  • node.js 从基础到操作数据库
  • vscode css智能补全_在 Webstorm 伤透我的心后,我决定尝试 VS Code
  • Js定时器倒计时及堆叠问题解析(附源码)
  • Webstorm干货(开发效率快到飞起!!!)
  • webstorm配置和使用
  • webstorm 风扇一直响_在 Webstorm 伤透我的心后,我决定尝试 VS Code
  • 如何使用 Javascript 截断/切片/修剪字符串中的最后一个字符?
  • 宝塔安装Jdk1.8
  • curl php 宝塔 开启_宝塔安装php失败
  • 安装宝塔后手动安装php,宝塔 安装 php扩展步骤
  • 测试工具和测试自动化
  • Linux下自动化工具
  • 自动化测试概述/自动化工具
  • 自动化测试工具简介
  • 【选型】常用的自动化测试工具
  • 如何选择合适的网络自动化工具
  • 十大最佳自动化测试工具
  • Python自动化工具(自动化操作)
  • 推荐一个强大的工作流自动化工具...
  • 自动化测试.工具