贪吃蛇的小程序

1 创建项目

1.打开微信开发者工具如图所示的界面,点击“+
在这里插入图片描述
2.填写项目以后,点击确定即可。如图所示:在这里插入图片描述

2 编程

1.编写index.wxml的代码如下:

<view class="container"><canvas style="width:100%;height:100%;" canvas-id="firstCanvas" bindtouchstart="canvasStart" bindtouchmove="canvasMove" bindtouchend="canvasEnd"></canvas>
</view>

如图所示:在这里插入图片描述
2.编写index.js的代码如下:

//index.js贪吃蛇主程序
//获取应用实例
var app = getApp()
//控制蛇头当前移动的位置
var l = 0;
var t = 0;
//蛇头的大小
var w = 10;
var h = 10;//手指的坐标
var startX = 0;
var startY = 0;
var moveEndX = 0;
var moveEndY = 0;
var X = 0;
var Y = 0;
//蛇头移动的方向
var direction = null;
var snakeDirection = "right";
//窗口的宽度和高度
var windowWidth = 0;
var windowHeight = 0;//存放身体的位置信息
var snakeBodys = [];//存放食物的位置信息
var foods = [];//蛇头对象
var snakeHead = {};//是否删除蛇的身体
var removeBodyBol = true;Page({canvasStart:function (e){startX = e.touches[0].x;startY = e.touches[0].y;},canvasMove:function (e){moveEndX = e.touches[0].x;moveEndY = e.touches[0].y;X = moveEndX - startX;Y = moveEndY - startY;if ( Math.abs(X) > Math.abs(Y) && X > 0 ) {direction = "right";}else if ( Math.abs(X) > Math.abs(Y) && X < 0 ) {direction = "left";}else if ( Math.abs(Y) > Math.abs(X) && Y > 0) {direction = "bottom";}else if ( Math.abs(Y) > Math.abs(X) && Y < 0 ) {direction = "top";}},canvasEnd:function (e){switch (direction){case "left":if(snakeDirection != "right"){snakeDirection  = direction;}break;case "right":if(snakeDirection != "left"){snakeDirection  = direction;}break;case "top":if(snakeDirection != "bottom"){snakeDirection  = direction;}break;case "bottom":if(snakeDirection != "top"){snakeDirection  = direction;}break;}console.log(snakeDirection);},onLoad: function () {//随机函数function rand(min,max){return parseInt(Math.random()*(max-min)+min);}//碰撞函数function collide(obj1,obj2){var l1 = obj1.x;var r1 = l1+obj1.w;var t1 = obj1.y;var b1 = t1+obj1.h;var l2 = obj2.x;var r2 = l2+obj2.w;var t2 = obj2.y;var b2 = t2+obj2.h;if (r1>l2&&l1<r2&&b1>t2&&t1<b2){return true;}else{return false;}}//食物的构造函数function Food(){this.x = rand(0,windowWidth-10);this.y = rand(0,windowHeight-10);this.w = 8;this.h = 8;this.color = "rgb("+rand(0,255)+","+rand(0,255)+","+rand(0,255)+")";this.resetPos = function (){this.x = rand(0,windowWidth-10);this.y = rand(0,windowHeight-10);}}//使用wx.createContext获取绘图上下文contextvar context = wx.createContext();var frameTime = 0;function move(){switch (snakeDirection){case "left":l -= w;break;case "right":l += w;break;case "top":t -= h;break;case "bottom":t += h;break;}}function animate(){frameTime++;if (frameTime%20==0){//把上一个位置存入身体数组snakeBodys.push({x:l,y:t,w:w,h:h});//控制舌头的位置移动move();//修改蛇头对象属性snakeHead = {x:l,y:t,w:w,h:h}//绘制食物for (var i=0; i<foods.length; i++){var food = foods[i];context.setFillStyle(food.color);context.beginPath();context.rect(food.x,food.y,food.w,food.h);context.closePath();context.fill();//食物跟蛇头碰撞检测if (collide(food,snakeHead)){console.log('装上了');food.resetPos();removeBodyBol = false;}}//绘制蛇头context.setFillStyle("#ff00ff");context.beginPath();context.rect(l,t,w,h);context.closePath();context.fill();//如果超过4截身体就删除最老的那一截if (snakeBodys.length > 6){if (removeBodyBol){snakeBodys.shift();}else{removeBodyBol = true;}}//绘制身体for (var i=0; i<snakeBodys.length; i++){var snakeBodyObj = snakeBodys[snakeBodys.length-i-1];context.setFillStyle("#000000");context.beginPath();context.rect(snakeBodyObj.x,snakeBodyObj.y,snakeBodyObj.w,snakeBodyObj.h);context.closePath();context.fill();}wx.drawCanvas({canvasId: "firstCanvas",actions: context.getActions()});}requestAnimationFrame(animate);}//获取页面的宽度wx.getSystemInfo({success: function(res) {windowWidth = res.windowWidth;windowHeight = res.windowHeight;//在页面中随机初始化创建30个食物for (var i=0; i<30; i++){var foodObj = new Food();foods.push(foodObj);}animate();}})}
})

如图所示:在这里插入图片描述
3.编写index.wxss的代码如下:

page{height: 100%;width: 100%;
}
canvas{background-color: #ccc;
}

如图所示:在这里插入图片描述
4.修改app.js的代码如图所示:在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/65405.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Python游戏】贪吃蛇升级版——双人贪吃蛇小游戏 | 附带源码

前言 之前做过一个单人版的贪吃蛇&#xff0c;所以常常就是我只能看着别人玩&#xff0c;或者别人看着我玩&#xff0c;却没法两个人一起愉快地玩耍。 由此产生了做一个可以双人玩的贪吃蛇想法&#xff0c;并且从小时候一直到现在&#xff0c;之前python还没有那么火的时候&am…

html版贪吃蛇

<!doctype html><html><head></head><body> <div id"box" style"width:256px;font:25px/25px 宋体;background:#000;color:#9f9;"></div><script> var arr[15]; var next10;//最好判断一下arr[1]!arr[0]x…

贪吃蛇智能版(高级)

说明&#xff1a; 在贪吃蛇智能版&#xff08;中级&#xff09;的基础之上&#xff0c;增加了判断小食物是否安全的方法&#xff0c;并且增加了在寻找食物路径失败和寻找尾巴失败之后&#xff0c;会进行一小段的随机溜达&#xff0c;直到重新找到路径为止&#xff0c;当然这段…

贪吃蛇微信小程序源码

每日分享两个小程序源码 下载地址&#xff1a;无极低码&#xff1a;wheart.cnhttps://wheart.cn/so/home?mdw&ridf6d836c8-d54a-11ed-96fa-52540016e6ac <!--snake.wxml--> <view class"control" bindtouchstart"tapStart" bindtouchmove&qu…

win10系统激活提示无法连接到你组织的激活服务器如何解决

1、在桌面新建一个文本文档&#xff0c;把以下代码复制进去&#xff0c;如图所示&#xff1a; slmgr /ipk W269N-WFGWX-YVC9B-4J6C9-T83GX slmgr /skms kms.03k.org slmgr /ato 2、点击文件选择“另存为”&#xff0c;在弹出的界面中&#xff0c;将保存位置选择在桌面&#xff…

无法在此设备上激活WINDOWS因为无法连接到你的组织的激活服务器

在搜索框里搜索 cmd&#xff0c; 使用管理员权限运行&#xff0c;执行一句命令&#xff1a; slmgr /skms http://kms.03k.org点完回车以后&#xff0c;再打一句命令激活 slmgr /ato查激活日期 按下Windows R &#xff0c;输入cmd&#xff0c;出来dos对话框后&#xff0c;输入…

microsoft微软登录新账户/切换账户失败,一直转圈,提示“你似乎没有连接到internet”

无论有没有微软账户&#xff0c;是切换账户还是新电脑登录&#xff0c;原理都是一样的&#xff0c;先使用一个账号注册/登录/设置好微软账户&#xff0c;然后再进行你原本的操作。 在可以进入到桌面并且联网的情况下&#xff0c;登录不上微软账户的几种常用解决方法&#xff1…

登录微软账号时无法连接到网络

登录微软账号时无法连接到网络 关闭代理&#xff0c;手动设置ipv4DNS地址&#xff08;微软dns服务器&#xff1a;4.2…2.1)&#xff0c;改完记得改回来。

解决微软newbing chat的Sorry, looks like your network settings are preventing access to this featur问题

2023.03.25最近大家都有疑惑&#xff0c;已经"魔法"了&#xff0c;突然newbing chat用不了&#xff0c;弹出“Sorry, looks like your network settings are preventing access to this featur”&#xff0c; 已下是解决方法&#xff08;步骤操作的前提&#xff1a;…

成功解决长时间挂起虚拟机后再次打开无法连接网络,并提示网络激活失败(亲测有效)

成功解决长时间挂起虚拟机后再次打开无法连接网络&#xff0c;并提示网络激活失败&#xff08;亲测有效&#xff01;&#xff09; 之前做区块链的一个虚拟机很久没打开&#xff0c;一直处于挂起状态&#xff0c;一直提示网络连接激活失败。试了很多种方法没解决&#xff0c;更…

专治疑难系列 - 无法激活网络的解决方法

‍‍&#x1f3e1;博客主页&#xff1a; Passerby_Wang的博客_CSDN博客-系统运维,云计算,Linux基础领域博主 &#x1f310;所属专栏&#xff1a;『转治疑难系列』 &#x1f30c;上期文章&#xff1a; 无 &#x1f4f0;如觉得博主文章写的不错或对你有所帮助的话&#xff0c;还…

Nature综述:应对新出现的抗真菌耐药性对人类健康的威胁

编译&#xff1a;微科盟小木&#xff0c;编辑&#xff1a;微科盟居居、江舜尧。 微科盟原创微文&#xff0c;欢迎转发转载&#xff0c;转载须注明来源《微生态》公众号。 导读 侵袭性真菌感染对公共健康构成了重大威胁&#xff0c;是抗菌素耐药性的一个未得到充分认识的组成部分…

在传染病中,肠道微生物-免疫力-营养在优化治疗策略中的作用

谷禾健康 传染病&#xff0c;肠道微生物&#xff0c;营养 传染病和感染目前是许多地区尤其是低收入国家主要死亡原因&#xff0c;也是婴儿和老年人等弱势群体的主要风险。免疫系统在这些感染的易感性、持续性和清除中起着至关重要的作用。由于 70-80% 的免疫细胞存在于肠道中&a…

Microbiome:人类肠道和病原菌的可移动抗性组驱动环境中抗生素抗性增长

点击蓝字 关注我们 编译&#xff1a;张璐 校稿&#xff1a;张慧林 论文ID 原名&#xff1a;Mobile resistome of human gut and pathogen drives anthropogenic bloom of antibiotic resistance 译名&#xff1a;人类肠道和病原菌的可移动抗性组驱动环境中抗生素抗性增长 第…

抗生素对微生物组和人体健康的影响

谷禾健康 说起抗生素&#xff0c;可能会觉得有些抽象&#xff0c;那如果说阿莫西林、头孢、红霉素、阿奇霉素等等这些日常生活经常使用的药物&#xff0c;会不会有一些熟悉的感觉。当我们发现身体有一些小炎症(如头痛发热、喉咙痒疼、咳嗽)的时候&#xff0c;首先会想到要使用这…

肠道菌群、性激素与疾病:探索它们的交互作用

谷禾健康 我们的身体中有很多不同的器官&#xff0c;组织&#xff0c;腺体等会产生许多信号分子来精确控制和影响身体的反应和活动&#xff0c;这些信号分子包括激素、神经递质、生长因子、细胞因子等。它们可以促进或抑制细胞的生长和分化&#xff0c;调节细胞间的相互作用和通…

抗生素对肠道微生物群的影响

在与细菌性疾病的斗争中&#xff0c;抗生素是不可避免的。抗生素是人类使用了几十年的治疗细菌感染的救命药物。 虽然抗生素挽救了数百万人的生命&#xff0c;但它们也会消灭一些常驻细菌。现有文献已经确定了与抗生素相关的肠道微生物群失调&#xff08;多样性降低&#xff09…

国外问卷调查项目详解(真正的保姆级教程)

大家好&#xff0c;我是小飞匠&#xff0c;也聊了不少关于国外问卷调查项目的话题&#xff0c;但是不少朋友对于国外问卷调查还是不太了解&#xff0c;今天来做一个国外问卷调查项目详解(全网最全最细致的教程)&#xff0c;如果能够给到大家一点点帮助那也是极好的。 什么是国…

扒一扒传智播客深藏在背后的内幕

扒一扒传智播客深藏在背后的内幕 —— 传智坚持开Java基础班有何猫腻 Java基础太简单&#xff0c;自学一个月就能搞定&#xff1f;大学学了计算机基础的&#xff0c;感觉报基础班有点浪费钱&#xff0c;浪费时间&#xff01;找工作会项目都行了&#xff0c;基础班感觉没多大用…

“马导”怒怼“小鲜肉”,当马儿遇到配音,短视频内容让人捧腹

“马导”怒怼“小鲜肉”&#xff0c;当马儿遇到配音&#xff0c;短视频内容让人捧腹 搞笑配音短视频其实是非常受人欢迎的&#xff0c;尤其是有才华的作者为小动物们配上的搞笑配音&#xff0c;更是让小动物们有了一种拟人的感觉&#xff0c;叫人一看就觉得非常有趣。比如关于以…