很久很久以前,差不多大半年前吧,笔者发布了一篇关于OC版贪食蛇开发的文章,时隔多月,微信小程序横空出世,于是闲来无事的我又写了一个小程序版

下面这段话请务必阅读

笔者是做iOS的,而小程序大部分都是前端的知识,笔者之前没有做过类似开发,所以代码写的相当烂,很多东西都是一边查资料一边写的,请各位轻喷,阿门!

进入正题

页面布局

关于小程序笔者就不做介绍了,官方有详细文档,我们还是先来看张图吧

就是这个样子的,游戏界面跟之前的OC版是差不多的,以笔者的水平,只能设计成这样了,毕竟不是专业的,话说这蛇怎么长的像个J(和)B(谐)啊:joy:

先来看看用来添加组件的wxml文件

up

left

{{btnTitle}}

right

down

内容是相当简单滴,上面一个view,里面放一个画布,下面一个view,里面放5个按钮

再来看看wxss布局

内容不多,其实笔者对CSS也不是很了解,很多年前学习过,然而早随着:hankey:排出去了,也许还有更优的布局方式,不过凑合着用吧

功能实现

布局还是很简单的,虽然不熟,但是多尝试几下还是可以弄出来的,接下来功能逻辑的实现才是重点,编程语言当然是js了。

话说笔者当年学js的时候,可是写了满满一本的笔记,然而......算了,过去的就让他过去吧,往事不提也罢。

思路其实与OC版的一样

蛇:创建一个点坐标数组,然后以坐标点为中心在画布上画矩形

食物:随机一个坐标点,该点不能在蛇身上,否则重新随机

蛇的移动:把蛇尾的坐标移到蛇头前面就行了

吃到食物:每次蛇移动完毕后,如果蛇头的坐标与食物的坐标一样,则蛇增长

蛇的增长:在蛇尾后面加一个点坐标即可

游戏结束:蛇头越界或撞到自己身体即游戏结束

创建蛇//创建蛇,初始为5节,nodeWH为矩形的边长

function createSnake(){

nodes.splice(0, nodes.length) //清空数组

for (var i = 4; i >= 0; i--) {

var node = new Node(nodeWH * (i + 0.5), nodeWH * 0.5)

nodes.push(node);

}

}

创建食物function createFood(){

//矩形的边长为10,画布宽度为250,高度为350,所以x只能取5-245,y只能取5-345

var x = parseInt(Math.random() * 24) * nodeWH + nodeWH * 0.5

var y = parseInt(Math.random() * 34) * nodeWH + nodeWH * 0.5

//如果食物的坐标在蛇身上,则重新创建

for (var i = 0; i < nodes.length; i++) {

var node = nodes[i]

if (node.x == x && node.y == y) {

createFood()

return

}

}

//Node为自定义的类,有两个属性x和y,表示坐标

food = new Node(x,y)

}

蛇的移动

蛇的移动是有方向的,所以用一个变量direction来记录蛇的移动方向,游戏开始时,默认是向右移动。

上面有说到蛇的移动就是把蛇尾的坐标移到蛇头前面,但是这个前面并不是固定的,而是根据方向来判断的,如果向右移动则右边为前方,以此类推

吃到食物与蛇增长

每次移动完毕后,判断蛇头的坐标是否与食物的坐标相等就OK了,吃到食物后蛇的长度会增加,并且要创建一个新的食物function isEatedFood(){

var head = nodes[0]

if (head.x == food.x && head.y == food.y) {

score++

nodes.push(lastPoint)

createFood()

}

}

上面的代码中,lastPoint就是蛇每次移动前,蛇尾的坐标,如果移动后吃到食物,那么直接在移动前的蛇尾处加上一节即可

游戏结束

每次移动后,都要判断蛇头是否超过画布,或者撞到自己的身体function isDestroy(){

var head = nodes[0]

//判断是否撞到自己身体

for (var i = 1; i < nodes.length; i++) {

var node = nodes[i]

if (head.x == node.x && head.y == node.y) {

gameOver()

}

}

//判断水平方向是否越界

if (head.x < 5 || head.x > 245) {

gameOver()

}

//判断垂直方向是否越界

if (head.y < 5 || head.y > 345) {

gameOver()

}

}

界面绘制

每次移动都要绘制,所以需要一个定时器,笔者用的setIntervalfunction move(){

lastPoint = nodes[nodes.length - 1]

var node = nodes[0]

var newNode = {x: node.x, y: node.y}

switch (direction) {

case 'up':

newNode.y -= nodeWH;

break;

case 'left':

newNode.x -= nodeWH;

break;

case 'right':

newNode.x += nodeWH;

break;

case 'down':

newNode.y += nodeWH;

break;

}

nodes.pop()

nodes.unshift(newNode)

moveEnd()

}

function startGame() {

if (isGameOver) {

direction = 'right'

createSnake()

createFood()

score = 0

isGameOver = false

}

timer = setInterval(move,300)

}

网上说setInterval的性能并不怎么好,建议用requestAnimationFrame,但是很遗憾,笔者不会用,准确的说是不知道怎么暂停var animateId = 0

function move(){

.

.

.

animateId = requestAnimationFrame(move)

}

function startGame(){

.

.

.

animateId = requestAnimationFrame(move)

}

使用上面的方法可以实现蛇的移动与界面重绘,然而每次执行animateId都会被赋予新的值,所以使用cancelAnimationFrame(animateId)无法暂停,如果有懂前端开发的大神请指导下

差不多整个逻辑就是这样的,喜欢研究的可以自己尝试下

【相关推荐】

贪吃蛇程序 php,微信小程序-贪吃蛇教程实例相关推荐

  1. 《微信小程序》微信小程序开发实例

    wx-gesture-lock  微信小程序的手势密码 WXCustomSwitch 微信小程序自定义 Switch 组件模板 WeixinAppBdNovel 微信小程序demo:百度小说搜索 sh ...

  2. 谷歌小程序和微信小程序,你更看好哪个?

    微信"小程序"无疑是16年年末最火爆的新技术,美国时间1月24日,谷歌也推出自己了"小程序"--Android Instant Apps,谷歌.微信都在做的小程 ...

  3. map和foreach的区别和应用场景_支付宝小程序和微信小程序,两者有何区别?

    原标题:支付宝小程序和微信小程序,两者有何区别? 自2017年1月微信推出小程序之后,小程序的发展势头便愈来愈猛.作为腾讯老对头的阿里,也开始投入小程序的研发.在一年多的开放公测后,支付宝小程序终于于 ...

  4. 怎么添加一个程序集_门店小程序,微信小程序怎么添加店铺

    现今随着互联网发展,越来越多选择网上购物代替实体店购物,微信作为最多人使用的社交软件,他的商机也被许多企业商家发展,进入微信分销小程序购物是现在最流行的购物方式,驱使很多实体店也纷纷加盟进驻门店分销小 ...

  5. 【小程序】微信小程序开发技巧实用手册(自己做笔记用)

    [Css]Css和Html常用设计实例参考笔记(自己开发项目用)_敦厚的曹操的博客-CSDN博客_html和css的项目实例一.左右居中1.div等块元素左右居中margin: 0 auto;marg ...

  6. 如何制作一个微信小程序【微信小程序是怎么做的】

    为什么现在这么多人使用微信小程序呢?因为微信小程序除了便捷易开发,公司企业可以用来做小程序展示官网,商家也可以做小程序商城,甚至个人也可以拥有自己的小程序.那么如何制作一个微信小程序?微信小程序是怎么 ...

  7. 个人怎么制作微信小程序,微信小程序可以免费制作吗?微信小程序制作教程

    微信小程序 微信小程序,小程序的一种,英文名Wechat Mini Program,是一种不需要下载安装即可使用的应用,它实现了应用"触手可及"的梦想,用户扫一扫或搜一下即可打开应 ...

  8. PHP:【微信小程序】初识微信小程序,微信小程序配置

    PHP:[微信小程序]初识微信小程序,微信小程序配置 一.介绍 小程序提供了一个简单.高效的应用开发框架和丰富的组件及 API,帮助开发者在微信中开发具有原生 APP 体验的服务 小程序是一种全新的连 ...

  9. (微信小程序)微信小程序-毕设级项目搭建-微信阅读小程序(内含源码,微信小程序+java逻辑后台+vue管理系统)~不求完美,实现就好

    转载地址:(微信小程序)微信小程序-毕设级项目搭建-微信阅读小程序(内含源码,微信小程序+java逻辑后台+vue管理系统)~不求完美,实现就好 转载请注明出处 作者:Happy王子乐 个人网站(整理 ...

  10. 智慧物业小程序_物业小程序物业微信小程序目前功能最全的物业小程序

    原标题:物业小程序物业微信小程序目前功能最全的物业小程序 以物业管理为核心,打造智慧社区云微信小程序管理平台,已入驻腾讯海纳社区,物业微信小程序,解决传统物业管理难,乱差的问题,利用微信小程序提供一整 ...

最新文章

  1. 面试官:你说你熟悉jvm?那你讲一下并发的可达性分析
  2. php数据库缓存类,常见php数据文件缓存类汇总
  3. 内存泄漏分析 mat 使用 activity泄漏
  4. tomcat异常处理经验汇总
  5. 1+X web中级 Laravel学习笔记——使用DB facade对数据库进行增删改查
  6. 【组件化开发】前端进阶篇之如何编写可维护可升级的代码
  7. 致盲目标检测算法,阿里清华发起 “对抗攻击” 挑战赛!
  8. ASP.NET中的Cookie对象
  9. 触控屏c语言程序,TouchWin编程软件下载_TouchWin触摸屏软件下载 2.D.2c 官网版_当载软件站...
  10. 使用C#创建一个简单的Windows服务
  11. c语言数字分解一个数,关于一道分解整数为N个连数整数的编程题
  12. 论文《Efficient Large-Scale Stereo Matching》学习
  13. 【BCM】博通 linux-4.19 gcc-9.2 toolchain 环境搭建
  14. 初次使用MarkDown编辑器
  15. Java实现文件搜索
  16. 《都挺好》苏明哲为什么会失业,美国程序员不好找工作吗?
  17. php多商品规格统计数量
  18. 生成拼音语料及拼音识别转换成中文
  19. LNK2019 unresolved external symbol __iob_func referenced in function _OPENSSL_stderr
  20. LeetCode 110 Balanced Binary Tree

热门文章

  1. 在linux中编写shell脚本文件,如何编写简单的Shell脚本(Script)文件之Linux的基本操作...
  2. 安卓mysql插入数据_【11-25求助】关于Android 的SQLite数据库插入数据报错问题
  3. mgg mysql_mgg文件怎么转换mp3格式?
  4. 如何在 Linux 中快速地通过 HTTP 提供文件访问服务
  5. Linux清mysql磁盘,mysql与linux ~ 磁盘分析与调优
  6. python数据预处理 重复行统计_Python数据分析之数据预处理(数据清洗、数据合并、数据重塑、数据转换)学习笔记...
  7. 容大打印机ip修改工具_M1芯片版Mac无法连接打印机怎么办?
  8. python 如何快速判断列表是否相同_Python-检查列表中的所有元素是否相同
  9. java异常处理方式推荐做法_谈谈Java异常处理这件事儿
  10. sp_addlinkedserver oracle,sp_addlinkedserver使用方法