vue实现2048小游戏功能思路详解


Posted in Javascript onMay 09, 2018

试玩地址

项目地址

使用方法:

git clone
npm i
npm run dev

实现思路如下:

  1. 用vue-cli搭建项目,对这个项目可能有点笨重,但是也懒的再搭一个
  2. 4X4的方格用一个二维数组存放,绑定好后只关心这个二维数组,其他事交给vue
  3. 监听键盘事件
  4. 2048的核心部分就是移动合并的算法,因为是一个4X4的矩阵,所以只要实现左移的算法,其他方向的移动只需要将矩阵旋转,移动合并,再旋转回来,渲染dom即可
  5. 绑定不同数值的样式
  6. 分值计算,以及用localstorage存放最高分

关键实现

DOM

<div class="box">
  <div class="row" v-for="row in list">
    <div class="col" :class="'n-'+col" v-for="col in row">{col}}</div>
  </div>
</div>

主要的游戏部分的DOM,很简单,用一个二维数组渲染,并动态绑定样式

左移

主要由以下几种情况:

  • 2 2 2 2 => 4 4 0 0
  • 4 2 2 2 => 4 4 2 0
  • 0 4 2 2=> 4 4 0 0
  • 2 2 4 2 => 4 4 2 0

按单行数据举例,

  1. 遍历单行数组,若存在数据,记为cell,寻找cell往左可移到的最远空位置farthest
  2. 判断farthest的左边是否存在,不存在则直接移到到farthest
  3. 若存在,则判断farthest - 1的值和cell是否相同
  4. 相同=> 合并
  5. 不相同=>移到farthest位置
  6. 移动完后,清空cell
  7. 下一轮

因为一轮移动中,一个数只能合并一次,所以每个格子要有merged参数来记录是否已经合并过。

主要代码:

_list.forEach(item => {
    let farthest = this.farthestPosition(list, item)
    let next = list[farthest - 1]
    if (next && next === item.value && !_list[farthest - 1].merged) {
      //合并
      list[farthest - 1] = next * 2
      list[item.x] = undefined
      item = {
        x: farthest - 1,
        merged: true,
        value: next * 2
      }
      this.score += next * 2
    } else {
      if (farthest != item.x) {
        list[farthest] = item.value
        list[item.x] = undefined
        item.x = farthest
      }
    }
  })

矩阵旋转

因为上移,下移,左移,右移实际上是相同的,写4遍也可以,但是容易出错,所以我直接旋转将矩阵旋转,再进行移动。

以上移为例,只要将矩阵逆时针旋转一次,上移就变成了左移,移动合并成之后,只要再将矩阵逆时针旋转4-1次,矩阵就和单纯上移一样了。

逆时针旋转算法:

rotate(arr, n) {
    n = n % 4
    if (n === 0) return arr
    let tmp = Array.from(Array(this.size)).map(() => Array(this.size).fill(undefined))
    for (let i = 0; i < this.size; i++) {
      for (let j = 0; j < this.size; j++) {
        tmp[this.size - 1 - i][j] = arr[j][i]
      }
    }
    if (n > 1) tmp = this.rotate(tmp, n - 1)
    return tmp
  },

到这时候已经完成了80%了,只要再完善一下,加入分值,重新开始等功能就可以了。

总结

以上所述是小编给大家介绍的vue实现2048小游戏功能思路详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
Jquery Ajax学习实例 向页面发出请求,返回XML格式数据
Mar 14 Javascript
UpdatePanel和Jquery冲突的解决方法
Apr 01 Javascript
jQuery实现跨域
Feb 03 Javascript
浅谈$(document)和$(window)的区别
Jul 15 Javascript
jQuery简单设置文本框回车事件的方法
Aug 01 Javascript
Node.js中常规的文件操作总结
Oct 13 Javascript
详解Node.js:events事件模块
Nov 24 Javascript
JS使用面向对象技术实现的tab选项卡效果示例
Feb 28 Javascript
Vue实现动态响应数据变化
Apr 28 Javascript
解决layui上传文件提示上传异常,实际文件已经上传成功的问题
Aug 19 Javascript
Angularjs Ng_repeat中实现复选框选中并显示不同的样式方法
Sep 12 Javascript
vue+elementUI实现表格关键字筛选高亮
Oct 26 Javascript
vue中父子组件注意事项,传值及slot应用技巧
May 09 #Javascript
vue中的provide/inject的学习使用
May 09 #Javascript
详解Vue 多级组件透传新方法provide/inject
May 09 #Javascript
自定义vue组件发布到npm的方法
May 09 #Javascript
React Navigation 使用中遇到的问题小结
May 08 #Javascript
官方推荐react-navigation的具体使用详解
May 08 #Javascript
JavaScript callback回调函数用法实例分析
May 08 #Javascript
You might like
[原创]效率较高的php下读取文本文件的代码
2008/07/02 PHP
win7 64位系统 配置php最新版开发环境(php+Apache+mysql)
2014/08/15 PHP
php 解决substr()截取中文字符乱码问题
2016/07/18 PHP
Jquery中children与find之间的区别详细解析
2013/11/29 Javascript
详解Angular.js指令中scope类型的几种特殊情况
2017/02/21 Javascript
JS实现无缝循环marquee滚动效果
2017/05/22 Javascript
详解AngularJS1.6版本中ui-router路由中/#!/的解决方法
2017/05/22 Javascript
Angular2里获取(input file)上传文件的内容的方法
2017/09/05 Javascript
微信小程序实现动态改变view标签宽度和高度的方法【附demo源码下载】
2017/12/05 Javascript
TypeScript类型声明书写详解
2019/08/28 Javascript
js实现跳一跳小游戏
2020/07/31 Javascript
[01:02]DOTA2上海特锦赛SHOWOPEN
2016/03/25 DOTA
Python(TensorFlow框架)实现手写数字识别系统的方法
2018/05/29 Python
对Python通过pypyodbc访问Access数据库的方法详解
2018/10/27 Python
Python将一个Excel拆分为多个Excel
2018/11/07 Python
Python tkinter模版代码实例
2020/02/05 Python
Python要如何实现列表排序的几种方法
2020/02/21 Python
升级keras解决load_weights()中的未定义skip_mismatch关键字问题
2020/06/12 Python
Python基础进阶之海量表情包多线程爬虫功能的实现
2020/12/17 Python
使用 CSS3 中@media 实现网页自适应的示例代码
2020/03/24 HTML / CSS
移动端开发HTML5页面点击按钮后出现闪烁或黑色背景的解决办法
2018/09/19 HTML / CSS
空指针到底是什么
2012/08/07 面试题
上班睡觉检讨书
2014/01/09 职场文书
写演讲稿要注意的六件事
2014/01/14 职场文书
校庆接待方案
2014/03/18 职场文书
党员创先争优活动总结
2014/05/04 职场文书
纪律教育月活动总结
2014/08/26 职场文书
银行授权委托书范本
2014/10/04 职场文书
离婚协议书范本2014
2014/10/27 职场文书
开展党的群众路线教育实践活动个人对照检查材料
2014/11/05 职场文书
2014年仓库工作总结
2014/11/20 职场文书
幼儿园小班工作总结2015
2015/04/25 职场文书
优秀学生干部主要事迹材料
2015/11/04 职场文书
再谈python_tkinter弹出对话框创建
2022/03/20 Python
IIS服务器中设置HTTP重定向访问HTTPS
2022/04/29 Servers
python数字图像处理:图像的绘制
2022/06/28 Python