微信小程序:贪吃蛇

微信小程序:贪吃蛇

wx.js

var startX = 0;
var startY = 0;
var moveX = 0;
var moveY = 0;
//移动位置和开始位置的坐标差值
var X = 0;
var Y = 0;
//蛇的对象
var snake = {x: 0,y: 0,color: "#ff0000", w: 20,h: 20,
}
//食物对象
var food = {x: 0,y: 0,color: "#ff0000", w: 20,h: 20,
}
//蛇身对象数据
var snakeArr = [];
//方向
var direction = "right";
var directio = null;
//窗口宽高
var windowWidth = wx.getSystemInfoSync().windowWidth;
var windowHeight = wx.getSystemInfoSync().windowHeight;
//食物数组
var foodArr = [];
//记录吃的食物数
var foodNum = 0;Page({
//按下获取坐标 touchs触摸
canvasStart:function(e){startX = e.touches[0].x;startY = e.touches[0].y;
},canvasMove:function(e){moveX = e.touches[0].x;moveY = e.touches[0].y;X=moveX - startX;Y=moveY - startY;if(Math.abs(X)>Math.abs(Y)&&X>0){directio="right"}else if(Math.abs(X)>Math.abs(Y)&&X<0){directio = "left"}else if(Math.abs(Y)>Math.abs(X)&& Y>0){directio = "bottom"}else if(Math.abs(Y)>Math.abs(X)&&Y<0){directio = "top"}direction = directio;
},onReady: function () {//获取画布上下文 对象var context = wx.createCanvasContext("snakCanvas", this);function draw(obj){context.setFillStyle(obj.color);context.beginPath();context.rect(obj.x,obj.y,obj.w,obj.h);context.closePath();context.fill();}setInterval(function animate(){switch (direction){case "left":  snake.x -= 20;break;case "right": snake.x += 20;break;case "top":   snake.y -= 20;break;case "bottom": snake.y += 20;break;}draw(snake)//绘制食物for (var i = 0; i < foodArr.length; i++) {var food = foodArr[i];draw(food);if(collide(snake,food)){//碰到食物 改变食物位置food.x = rand(0, windowWidth);food.y = rand(0, windowHeight);food.color = "rgb(" + rand(0, 255) + "," + rand(0, 255) + "," + rand(0, 255) + ")";var w = rand(10, 20);food.w = w;food.h = w;draw(food);}}//向蛇身体添加最新的位置snakeArr.push({x: snake.x,y: snake.y,w: 20,h: 20,color: "#fff000",});if(snakeArr.length>foodNum){ snakeArr.shift() }for(let i=0;i<snakeArr.length-1;i++){let body=snakeArr[i]draw(body)}context.draw();//界限if(snake.x>windowWidth){ snake.x=-20 }else if(snake.x<0){ snake.x=windowWidth }else if(snake.y>windowHeight){ snake.y=-20 }else if(snake.y<0){ snake.y=windowHeight }},300)//随机数function rand(max, min){ return parseInt(Math.random() * (max - min) + min)}//碰撞函数 obj1蛇 obj2 食物对象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){foodNum++//食物个数return true;} }//初始食物function foodstart(){for(let i=0;i<20;i++){food.x = rand(0, windowWidth);food.y = rand(0, windowHeight);var w = rand(10, 20);food.w = w;food.h = w; food.color = "rgb(" + rand(0, 255) + "," + rand(0, 255) + "," + rand(0, 255) + ")";foodArr.push(JSON.parse(JSON.stringify(food)))//制作食物并传到数组}} foodstart();//启动食物} 
})

WX.ML

<canvas canvas-id="snakCanvas" style="width:100%;height:100%;background-color:#ccc" 
bindtouchstart="canvasStart" bindtouchmove="canvasMove"></canvas>

WX.CSS

Page{height: 100%
}

在这里插入图片描述

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

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

相关文章

贪吃蛇的小程序

1 创建项目 1.打开微信开发者工具如图所示的界面&#xff0c;点击“ 2.填写项目以后&#xff0c;点击确定即可。如图所示&#xff1a; 2 编程 1.编写index.wxml的代码如下&#xff1a; <view class"container"><canvas style"width:100%;height:1…

【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;基础班感觉没多大用…