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 相关文章推荐
javascript 打开页面window.location和window.open的区别
Mar 17 Javascript
js汉字转拼音实现代码
Feb 06 Javascript
js控制iframe的高度/宽度让其自适应内容
Apr 09 Javascript
jQuery+easyui中的combobox实现下拉框特效
Feb 27 Javascript
理解Angular数据双向绑定
Jan 10 Javascript
原生js编写2048小游戏
Mar 17 Javascript
老生常谈ES6中的类
Jul 31 Javascript
jquery实现图片跟随鼠标的实例
Oct 17 jQuery
修改UA在PC中访问只能在微信中打开的链接方法
Nov 27 Javascript
Vue使用watch监听一个对象中的属性的实现方法
May 10 Javascript
利用js-cookie实现前端设置缓存数据定时失效
Jun 18 Javascript
js图片查看器插件用法示例
Jun 22 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 无限级 SelectTree 类
2009/05/19 PHP
php下封装较好的数字分页方法
2010/11/23 PHP
几种有用的变型 PHP中循环语句的用法介绍
2012/01/30 PHP
浅析php header 跳转
2013/06/17 PHP
深入解析phpCB批量转换的代码示例
2013/06/27 PHP
PHP 利用Mail_MimeDecode类提取邮件信息示例
2014/01/26 PHP
php操作redis中的hash和zset类型数据的方法和代码例子
2014/07/05 PHP
php操作csv文件代码实例汇总
2014/09/22 PHP
PHP中抽象类和抽象方法概念与用法分析
2016/05/24 PHP
PHP设计模式之注册树模式分析
2018/01/26 PHP
php基于 swoole 实现的异步处理任务功能示例
2019/08/13 PHP
PHP实现基本留言板功能原理与步骤详解
2020/03/26 PHP
浅谈PHP中的那些魔术常量
2020/12/02 PHP
Sample script that displays all of the users in a given SQL Server DB
2007/06/16 Javascript
node.js中的fs.lchownSync方法使用说明
2014/12/16 Javascript
JS实现漂亮的窗口拖拽效果(可改变大小、最大化、最小化、关闭)
2015/10/10 Javascript
jquery自定义表格样式
2015/11/23 Javascript
javascript中数组和字符串的方法对比
2016/07/20 Javascript
easyui datagrid 大数据加载效率慢,优化解决方法(推荐)
2016/11/09 Javascript
AngularJS指令与控制器之间的交互功能示例
2016/12/14 Javascript
jQuery实现CheckBox全选、全不选功能
2017/01/11 Javascript
微信小程序 支付功能开发错误总结
2017/02/21 Javascript
vue-froala-wysiwyg 富文本编辑器功能
2019/09/19 Javascript
vue单应用在ios系统中实现微信分享功能操作
2020/09/07 Javascript
[03:06]2018年度CS GO最具人气解说-完美盛典
2018/12/16 DOTA
python通过shutil实现快速文件复制的方法
2015/03/14 Python
Python单体模式的几种常见实现方法详解
2017/07/28 Python
python系统指定文件的查找只输出目录下所有文件及文件夹
2020/01/19 Python
TensorFlow tf.nn.softmax_cross_entropy_with_logits的用法
2020/04/19 Python
使用bandit对目标python代码进行安全函数扫描的案例分析
2021/01/27 Python
货代行业个人求职简历的自我评价
2013/10/22 职场文书
责任胜于能力演讲稿
2014/05/20 职场文书
课例研修方案
2014/05/31 职场文书
校车安全责任书
2014/08/25 职场文书
公务员岗前培训心得体会
2016/01/08 职场文书
文书工作总结(范文)
2019/07/11 职场文书