微信小程序项目实例——扫雷

news/2025/2/27 20:43:00/

今日推荐💁‍♂️


2023许嵩演唱会即将到来🎤🎤🎤大家一起冲冲冲🏃‍♂️🏃‍♂️🏃‍♂️
在这里插入图片描述

🔮🔮🔮🔮🔮往期优质项目实例🔮🔮🔮🔮🔮
微信小程序项目实例——图片处理小工具
🔗 https://blog.csdn.net/ws15168689087/article/details/125356342
微信小程序项目实例——我有一支画笔(画画)
🔗 https://blog.csdn.net/ws15168689087/article/details/124967906
微信小程序项目实例——印记
🔗 https://blog.csdn.net/ws15168689087/article/details/124606436
微信小程序项目实例——飞机大战
🔗 https://blog.csdn.net/ws15168689087/article/details/123153607
微信小程序项目实例——狼人杀
🔗 https://blog.csdn.net/ws15168689087/article/details/123307880

文章目录

    • 今日推荐💁‍♂️
    • 1️⃣ 项目介绍 👨‍🏫
    • 2️⃣ 项目结构 👨‍💻
    • 3️⃣ 项目展示 👨‍🎨
    • 4️⃣ 结尾 👨‍🎓

🌻🌻🌻🌼🌼🌼🌺🌺🌺🌼🌼🌼🌻🌻🌻

1️⃣ 项目介绍 👨‍🏫


🎃游戏介绍:
👉《扫雷》是一款大众类的益智小游戏,于1992年发行。游戏目标是在最短的时间内根据点击格子出现的数字找出所有非雷格子,同时避免踩雷,踩到一个雷即全盘皆输。

🎯PC端扫雷:
在这里插入图片描述

📑雷诀八条:
1️⃣基本定式不要忘,现场推理真够呛。
2️⃣鼠标点击不要快,稳定节奏把空开。
3️⃣顺手标雷不要惯,积累下来记录悬。
4️⃣无从下手不要愣,就近猜雷把心横。
5️⃣遇到猜雷不要怕,爆了脸上不留疤。
6️⃣猜雷猜错不要悔,哭天抢地也白费。
7️⃣碰上好局不要慌,紧盯局部慢扩张。
8️⃣痛失好局不要恨,既然有缘定有份。

项目展示:
👉扫雷小程序借鉴经典的PC端扫雷
👉玩家可以自行设置格子数🟫和地雷数💣
👉单点是开启,长按为插旗🚩

在这里插入图片描述

🤡🤡🤡🤡🤡🤡🤡🤡🤡🤡🤡🤡

2️⃣ 项目结构 👨‍💻


🎃项目目录:
在这里插入图片描述

🧑‍🚀核心代码:

<!--pages/game/game.wxml-->
<view class="page"><view class="section btns"><button bindtap="newGame">重新开始</button><button bindtap="handleSetting">游戏设置</button></view><view class="section"><view wx:for="{{grids}}" class="grid"><view wx:for="{{item}}" class="grid_cell" style="height:{{height}}rpx;"><view bindtouchstart="handleTouchStart" bindtouchend="handleTouchEnd" bindtap="handleClick" id="{{item}}" class="card {{cards[item].open?'open':''}}"><view wx:if="{{cards[item].open}}"><text wx:if="{{cards[item].boom}}" class="iconfont icon-zhadan-BOOM"></text><text wx:else>{{cards[item].num>0?cards[item].num:''}}</text></view><view wx:else><text wx:if="{{cards[item].flag}}" class="iconfont icon-qizhi" style="color:red"></text></view></view></view></view></view>
</view>
// pages/game/game.js
const app = getApp();
Page({data:{config: {x: 0,y: 0,n: 0},cards: [],grids: [],// arr: [],start: false,open: 0,touchStart:0,touchEnd:0,height: 0},onLoad:function(options){// 页面初始化 options为页面跳转所带来的参数},onReady:function(){// 页面渲染完成},onShow:function(){// 页面显示this.setData({config:{x:app.globalData.config.x,y:app.globalData.config.y,n:app.globalData.config.n},height: 750/app.globalData.config.x      });this.newGame();},onHide:function(){// 页面隐藏},onUnload:function(){// 页面关闭},newGame(){const x = this.data.config.x;const y = this.data.config.y;const n = this.data.config.n;const cards = [];const grids = [];// const arr = [];for(let i=0; i<y; i++){grids.push([]);for(let j=0; j<x; j++){const index = i*x+j;cards.push({index:index,boom:false,num:0,open:false,flag:false});grids[i].push(index);// arr.push(index);}}this.setData({cards: cards,grids: grids,// arr: arr,start: false,open: x*y-n});},handleClick(e){const i = parseInt(e.currentTarget.id);console.log(i);// console.log(this.data.touchEnd);// console.log(this.data.touchStart);const touchTime = this.data.touchEnd-this.data.touchStart;// console.log(touchTime);if(touchTime>350){const cards = this.data.cards;cards[i].flag = true;this.setData({cards:cards});}else{!this.data.start && this.setBoom(i);this.handleOpen(i);}},handleTouchStart(e){this.setData({touchStart:e.timeStamp});},handleTouchEnd(e){this.setData({touchEnd:e.timeStamp});},handleOpen:function(i){// const i = e.currentTarget.id;// console.log(i);// !this.data.start && this.setBoom(i);// this.getNeighbor(i);const cards = this.data.cards;if(cards[i].open){// console.log('OPENED!!!!!!!!!!!!!!!');return;}else{cards[i].open = true;this.setData({cards:cards,open:--this.data.open});console.log(this.data.open);if(this.data.open==0){wx.showModal({title: 'YOU WIN!!!!!',showCancel: false,success: function(res) {if (res.confirm) {// console.log('用户点击确定')this.newGame();}}.bind(this)});}}if(cards[i].boom){// console.log('boom!!!!!!!!!!!!!!!');wx.showModal({title: 'GAME OVER',showCancel: false,success: function(res) {if (res.confirm) {// console.log('用户点击确定')this.newGame();}}.bind(this)});}else if(cards[i].num==0){const ns = this.getNeighbor(i);ns.forEach(function(item){this.handleOpen(item);}.bind(this));}},setBoom:function(j){const cards = this.data.cards;// const arr = this.data.arr;const num = this.data.config.n;const newArr = this.getNeighbor(j).concat(j);// arr.splice(j,1);// const arr = [...Array(cards.length).keys()];const arr = [];for (let index of Array(cards.length).keys()) {newArr.indexOf(index)==-1 && arr.push(index);}// console.log(newArr);// console.log(arr);for(let i=0; i<num; i++){const index = Math.floor(Math.random()*arr.length);cards[arr[index]].boom = true;newArr.push(arr[index]);arr.splice(index,1);}const newCards = cards.map(function(card,i){let n = 0;this.getNeighbor(i).forEach(function(neighbor){cards[neighbor].boom && n++;});card.num = n;return card;}.bind(this));this.setData({arr:arr.concat(newArr),cards:newCards,start: true});},getNeighbor:function(i){const x = this.data.config.x;const y = this.data.config.y;// const arr = [i-x-1,i-x,i-x+1,i-1,i+1,i+x-1,i+x,i+x+1];const arr = [];!(i<x||i%x==0) && arr.push(i-x-1);!(i<x) && arr.push(i-x);!(i<x||i%x==(x-1)) && arr.push(i-x+1);!(i%x==0) && arr.push(i-1);// arr.push(i);!(i%x==(x-1)) && arr.push(i+1);!(i>=x*(y-1)||i%x==0) && arr.push(i+x-1);!(i>=x*(y-1)) && arr.push(i+x);!(i>=x*(y-1)||i%x==(x-1)) && arr.push(i+x+1);// console.log(arr);return arr},handleSetting:function(){wx.navigateTo({url: '../setting/setting'})}
})
🙈🙈🙈🙈🙈🙈🙈🙈🙈🙈🙈🙈

3️⃣ 项目展示 👨‍🎨


在这里插入图片描述

🧭🧭🧭🧭🧭🧭🧭🧭🧭🧭🧭

4️⃣ 结尾 👨‍🎓


具体的介绍就到这里了💭
扫雷小程序与PC经典的扫雷玩法一致🎰
有兴趣的同学可以继续研究🔎
代码放到下面链接里了👇
👉点击下载 扫雷小程序💣

在这里插入图片描述


http://www.ppmy.cn/news/33364.html

相关文章

【JavaEE初阶】第八节.网络原理网络层和数据链路层,应用层

文章目录 前言 一、网络层协议 1.1 IP协议 1.2 IP地址&#xff1b; 1.3 路由选择&#xff1b; 二、数据链路层 2.1 以太网协议&#xff1b; 三、应用层&#xff1b; 3.1 应用层协议DNS&#xff1b; 3.2 DNS是如何完成转换的&#xff1b; 3.3 如何解决DNS访问量太高的…

学习28个案例总结

学习前 对于之前遇到的问题没有及时总结&#xff0c;导致做什么事情都是新的一样。没有把之前学习到接触到的内容应用上。通过这次对28个案例的学习。把之前遇到的问题总结成自己的经验&#xff0c;在以后的开发过程中避免踩重复性的坑。多看帮助少走弯路。 学习中 对28个案例…

C/C++每日一练(20230319)

目录 1. 反转链表 II &#x1f31f;&#x1f31f; 2. 解码方法 &#x1f31f;&#x1f31f; 3. 擅长编码的小k &#x1f31f;&#x1f31f;&#x1f31f; &#x1f31f; 每日一练刷题专栏 &#x1f31f; Golang每日一练 专栏 Python每日一练 专栏 C/C每日一练 专栏 …

函数(上)——“Python”

各位CSDN的uu们你们好呀&#xff0c;今天小雅兰的内容是Python的函数呀&#xff0c;下面&#xff0c;就让我们进入函数的世界吧 首先可以选择性地看一下小雅兰很久之前写的C语言函数章节的知识&#xff1a; 函数——“C”_认真学习的小雅兰.的博客-CSDN博客 函数递归&#xf…

【批处理】- 批处理自动安装Mysql与Redis

前言 在全新环境中安装MySQL与Redis操作是挺麻烦的&#xff0c;于是就想使用脚本来自动安装&#xff0c;使用批处理进行一步到位的安装&#xff0c;后面还能使用工具进行打包成exe可执行文件&#xff0c;一键安装&#xff0c;最后能够更好的部署项目到windows系统的服务器。 …

Spring的数据库编程

1.JDBCTemplate 针对数据库操作&#xff0c;Spring框架提供了JdbcTemplate类,JdbcTemplate是一个模板类&#xff0c;Spring JDBC中的更高层次的抽象类均在JdbcTemplate模板类的基础上创建。JdbcTemplate类提供了操作数据库的基本方法&#xff0c;包括添加、删除、查询和更新。…

学习 Python 之 Pygame 开发魂斗罗(十二)

学习 Python 之 Pygame 开发魂斗罗&#xff08;十二&#xff09;继续编写魂斗罗1. 修改玩家扣减生命值2. 解决玩家下蹲子弹不会击中玩家而是直接让玩家死亡的问题3. 完善地图4. 增加产生敌人函数&#xff0c;解决一直产生敌人的问题5. 给玩家类增加计算玩家中心的方法继续编写魂…

“国产版ChatGPT”文心一言发布会现场Demo硬核复现

文章目录前言实验结果一、文学创作问题1 :《三体》的作者是哪里人&#xff1f;问题2&#xff1a;可以总结下三体的核心内容吗&#xff1f;如果要续写的话&#xff0c;可以从哪些角度出发&#xff1f;问题3&#xff1a;如何从哲学角度来进行续写&#xff1f;问题4&#xff1a;电…