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 相关文章推荐
prototype 的说明 js类
Sep 07 Javascript
javascript操作文本框readOnly
May 15 Javascript
Extjs中TabPane如何嵌套在其他网页中实现思路及代码
Jan 27 Javascript
php和js对数据库图片进行等比缩放示例
Apr 28 Javascript
Internet Explorer 11 浏览器介绍:别叫我IE
Sep 28 Javascript
js实现的鼠标滚轮滚动切换页面效果(类似360默认页面滚动切换效果)
Jan 27 Javascript
需灵活掌握的Bootstrap预定义排版类 你精通吗?
Jun 20 Javascript
微信小程序 wxapp内容组件 text详细介绍
Oct 31 Javascript
微信小程序 自己制作小组件实例详解
Dec 22 Javascript
angularJS 发起$http.post和$http.get请求的实现方法
May 18 Javascript
利用Javascript获取选择文本所在的句子详解
Dec 03 Javascript
vue动画之点击按钮往上渐渐显示出来的实例
Sep 29 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实现高效获取图片尺寸的方法
2014/12/12 PHP
php+mysql查询实现无限下级分类树输出示例
2016/10/03 PHP
如何用jQuery实现ASP.NET GridView折叠伸展效果
2015/09/26 Javascript
快速学习jQuery插件 Cookie插件使用方法
2015/12/01 Javascript
使用getBoundingClientRect方法实现简洁的sticky组件的方法
2016/03/22 Javascript
AngularJs 弹出模态框(model)
2016/04/07 Javascript
JS本地刷新返回上一页代码
2016/07/25 Javascript
bootstrap中模态框、模态框的属性实例详解
2017/02/17 Javascript
JavaScript中清空数组的三种方式
2017/03/22 Javascript
浅析JavaScript中的平稳退化(graceful degradation)
2017/07/24 Javascript
vue cli构建的项目中请求代理与项目打包问题
2018/02/26 Javascript
JS实现读取xml内容并输出到div中的方法示例
2018/04/19 Javascript
js继承的这6种方式!(上)
2019/04/23 Javascript
[03:55]显微镜下的DOTA2特别篇——430灰烬之灵神级操作
2014/06/24 DOTA
[56:18]DOTA2上海特级锦标赛主赛事日 - 4 败者组第四轮#2 MVP.Phx VS Fnatic第二局
2016/03/05 DOTA
Python中编写ORM框架的入门指引
2015/04/29 Python
Python编程中运用闭包时所需要注意的一些地方
2015/05/02 Python
Python实现股市信息下载的方法
2015/06/15 Python
Python网络编程详解
2017/10/31 Python
Python实现爬虫爬取NBA数据功能示例
2018/05/28 Python
flask框架自定义过滤器示例【markdown文件读取和展示功能】
2019/11/08 Python
Python TKinter如何自动关闭主窗口
2020/02/26 Python
python对一个数向上取整的实例方法
2020/06/18 Python
用sleep间隔进行python反爬虫的实例讲解
2020/11/30 Python
python判断all函数输出结果是否为true的方法
2020/12/03 Python
详解移动端html5页面长按实现高亮全选文本内容的兼容解决方案
2016/12/03 HTML / CSS
三年级数学教学反思
2014/01/31 职场文书
国际贸易专业个人求职信格式
2014/02/02 职场文书
庆元旦广播稿
2014/02/10 职场文书
进步之星获奖感言
2014/02/22 职场文书
教育技术学专业职业规划书
2014/03/03 职场文书
教师党员个人整改措施材料
2014/09/16 职场文书
个人租房协议书(范本)
2014/10/14 职场文书
校运会通讯稿
2015/07/18 职场文书
小学班主任培训心得体会
2016/01/07 职场文书
nginx前后端同域名配置的方法实现
2021/03/31 Servers