微信小程序:元宵灯笼连连看小游戏

2023-10-13 01:38

本文主要是介绍微信小程序:元宵灯笼连连看小游戏,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

20180301 by 慕容秋

写在前面

前些天闲聊中跟家里的领导说,微信也可以做小游戏诶。然后她说,那你做个连连看游戏给我玩玩呗。再然后就有了这几天的摸索和下面的一些小结:

演示效果: http://link.muroqiu.com

源码地址: https://gitee.com/muroqiu/LinkUp


开发工具:

  • Cocos Creator v1.8.1
  • Visual Studio Code 1.20.1
  • Adob illustrator CC 2018
  • 微信开发者工具 1.02.1802270

主要的工作是在Cocos Creator和Visual Studio Code里完成的,illustrator CC 用来资源切图,微信开发者工具是最后打包微信小游戏用到;Cocos Creator对微信小游戏的支持已经很到位了,游戏写好后只要在构建时选择发布平台为Wechat Game就好。

目前微信还未开放小游戏注册与上架,只能用开发者的微信测试体验。好在Cocos Creator跨平台发布很方便,构建了个Web Mobile版本,发布到服务器上,大家有兴趣就一起可以体验咯^_^

主要的逻辑:

A、洗牌 shuffle:遍历图片数组,取1个随机位置的图片和当前位置交换;

B、用一个二维数组(各个方向均比图片数组大1)保存图片的状态值,搜索路径时映射到这个数组搜索;

C、搜索顺序:

  • 1、同一条直线:判断直线间有无图片;
  • 2、有一个拐角:先定位出两个拐角点,若拐角点没有图片,再转换成一条直线的情况继续处理;
  • 3、两个拐角:某个方向移动,若到达点没有图片,再转换成一个拐角的情况继续处理;若到达点有图片,此方向不再继续搜索;
/*** 直连*/matchBlockLine: function (x1, y1, x2, y2) {// cc.warn('matchBlock  ' + x1 + ', ' + y1 + '  : ' + x2 + ', ' + y2); if (x1 != x2 && y1 != y2) {return false;}if (x1 == x2) {// 同一列 if (x1 < 0 || x1 >= this.rows) {return true;}var Ymin = Math.min(y1, y2) + 1;var Ymax = Math.max(y1, y2);for (Ymin; Ymin < Ymax; Ymin++) {if (this._canvasGrids[x1 + 1][Ymin + 1] > this._TYPE_INIT) {return false;}}} else if (y1 == y2) {// 同一行 if (y1 < 0 || y1 >= this.columns) {return true;}var Xmin = Math.min(x1, x2) + 1;var Xmax = Math.max(x1, x2);for (Xmin; Xmin < Xmax; Xmin++) {if (this._canvasGrids[Xmin + 1][y1 + 1] > this._TYPE_INIT) {return false;}}}return true;},


/*** 一个转角* 搜索到路径时,返回转角坐标 x3, y3*/matchBlockCorner: function (x1, y1, x2, y2, isAxis_X) {// cc.warn('matchBlockCorner  ' + x1 + ', ' + y1 + '  : ' + x2 + ', ' + y2); var result;// 直连的返回 if (x1 == x2 || y1 == y2) {return null;}// 转角点1 (x1, y2),Y方向 if (this._canvasGrids[x1 + 1][y2 + 1] <= this._TYPE_INIT && isAxis_X != false) {result = this.matchBlockCorner_point(x1, y1, x2, y2, x1, y2);if (result) {return result;}}// 转角点2 (x2, y1),X方向 if (this._canvasGrids[x2 + 1][y1 + 1] <= this._TYPE_INIT && isAxis_X != true) {result = this.matchBlockCorner_point(x1, y1, x2, y2, x2, y1);if (result) {return result;}}return null;},/*** 转角逻辑*/matchBlockCorner_point: function (x1, y1, x2, y2, x3, y3) {var stMatch = this.matchBlockLine(x1, y1, x3, y3);if (stMatch) {var tdMatch = this.matchBlockLine(x3, y3, x2, y2);if (tdMatch) {return [x3, y3];}}return null;},
/*** 两个转角* 由中心往外展开搜索路径,某个方向当碰到有图片时,这个方向就不再继续搜索* 搜索到路径时,返回两个转角点坐标 x3, y3, x4, y4*/matchBlockUnfold: function (x1, y1, x2, y2) {var result;var x3 = 0;var y3 = 0;var canUp = true;var canDown = true;var canLeft = true;var canRight = true;// cc.warn('matchBlockUnfold  ' + x1 + ', ' + y1 + '  : ' + x2 + ', ' + y2); for (var i = 1; i < this.rows; i++) {// 上x3 = x1;y3 = y1 + i;if (canUp && y3 <= this.columns) {canUp = this._canvasGrids[x3 + 1][y3 + 1] <= this._TYPE_INIT;result = this.matchBlockUnfold_axis(x1, y1, x2, y2, x3, y3, false);if (result) {return result;}}// 下x3 = x1;y3 = y1 - i;if (canDown && y3 >= -1) {canDown = this._canvasGrids[x3 + 1][y3 + 1] <= this._TYPE_INIT;result = this.matchBlockUnfold_axis(x1, y1, x2, y2, x3, y3, false);if (result) {return result;}}// 左x3 = x1 - i;y3 = y1;if (canLeft && x3 >= -1) {canLeft = this._canvasGrids[x3 + 1][y3 + 1] <= this._TYPE_INIT;result = this.matchBlockUnfold_axis(x1, y1, x2, y2, x3, y3, true);if (result) {return result;}}// 右x3 = x1 + i;y3 = y1;if (canRight && x3 <= this.rows) {canRight = this._canvasGrids[x3 + 1][y3 + 1] <= this._TYPE_INIT;result = this.matchBlockUnfold_axis(x1, y1, x2, y2, x3, y3, true);if (result) {return result;}}}return null;},/*** 某个方向上的搜索逻辑*/matchBlockUnfold_axis: function (x1, y1, x2, y2, x3, y3, isAxis_X) {// cc.warn("matchBlockUnfold_axis  " + x3 + ', ' + y3); var tmpXY = [];if (this._canvasGrids[x3 + 1][y3 + 1] <= this._TYPE_INIT) {tmpXY = this.matchBlockCorner(x3, y3, x2, y2, isAxis_X);if (tmpXY) {return [x3, y3].concat(tmpXY);;}}return null;},

参考资料

  • http://blog.csdn.net/artzok/article/details/51622782


作者:汀江秋雨
链接:jianshu.com/p/740603fc6
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
开启赞赏

这篇关于微信小程序:元宵灯笼连连看小游戏的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/199850

相关文章

微信公众号脚本-获取热搜自动新建草稿并发布文章

《微信公众号脚本-获取热搜自动新建草稿并发布文章》本来想写一个自动化发布微信公众号的小绿书的脚本,但是微信公众号官网没有小绿书的接口,那就写一个获取热搜微信普通文章的脚本吧,:本文主要介绍微信公众... 目录介绍思路前期准备环境要求获取接口token获取热搜获取热搜数据下载热搜图片给图片加上标题文字上传图片

如何用java对接微信小程序下单后的发货接口

《如何用java对接微信小程序下单后的发货接口》:本文主要介绍在微信小程序后台实现发货通知的步骤,包括获取Access_token、使用RestTemplate调用发货接口、处理AccessTok... 目录配置参数 调用代码获取Access_token调用发货的接口类注意点总结配置参数 首先需要获取Ac

基于Python开发PDF转Doc格式小程序

《基于Python开发PDF转Doc格式小程序》这篇文章主要为大家详细介绍了如何基于Python开发PDF转Doc格式小程序,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 用python实现PDF转Doc格式小程序以下是一个使用Python实现PDF转DOC格式的GUI程序,采用T

将java程序打包成可执行文件的实现方式

《将java程序打包成可执行文件的实现方式》本文介绍了将Java程序打包成可执行文件的三种方法:手动打包(将编译后的代码及JRE运行环境一起打包),使用第三方打包工具(如Launch4j)和JDK自带... 目录1.问题提出2.如何将Java程序打包成可执行文件2.1将编译后的代码及jre运行环境一起打包2

在不同系统间迁移Python程序的方法与教程

《在不同系统间迁移Python程序的方法与教程》本文介绍了几种将Windows上编写的Python程序迁移到Linux服务器上的方法,包括使用虚拟环境和依赖冻结、容器化技术(如Docker)、使用An... 目录使用虚拟环境和依赖冻结1. 创建虚拟环境2. 冻结依赖使用容器化技术(如 docker)1. 创

W外链微信推广短连接怎么做?

制作微信推广链接的难点分析 一、内容创作难度 制作微信推广链接时,首先需要创作有吸引力的内容。这不仅要求内容本身有趣、有价值,还要能够激起人们的分享欲望。对于许多企业和个人来说,尤其是那些缺乏创意和写作能力的人来说,这是制作微信推广链接的一大难点。 二、精准定位难度 微信用户群体庞大,不同用户的需求和兴趣各异。因此,制作推广链接时需要精准定位目标受众,以便更有效地吸引他们点击并分享链接

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听

EMLOG程序单页友链和标签增加美化

单页友联效果图: 标签页面效果图: 源码介绍 EMLOG单页友情链接和TAG标签,友链单页文件代码main{width: 58%;是设置宽度 自己把设置成与您的网站宽度一样,如果自适应就填写100%,TAG文件不用修改 安装方法:把Links.php和tag.php上传到网站根目录即可,访问 域名/Links.php、域名/tag.php 所有模板适用,代码就不粘贴出来,已经打

跨系统环境下LabVIEW程序稳定运行

在LabVIEW开发中,不同电脑的配置和操作系统(如Win11与Win7)可能对程序的稳定运行产生影响。为了确保程序在不同平台上都能正常且稳定运行,需要从兼容性、驱动、以及性能优化等多个方面入手。本文将详细介绍如何在不同系统环境下,使LabVIEW开发的程序保持稳定运行的有效策略。 LabVIEW版本兼容性 LabVIEW各版本对不同操作系统的支持存在差异。因此,在开发程序时,尽量使用

CSP 2023 提高级第一轮 CSP-S 2023初试题 完善程序第二题解析 未完

一、题目阅读 (最大值之和)给定整数序列 a0,⋯,an−1,求该序列所有非空连续子序列的最大值之和。上述参数满足 1≤n≤105 和 1≤ai≤108。 一个序列的非空连续子序列可以用两个下标 ll 和 rr(其中0≤l≤r<n0≤l≤r<n)表示,对应的序列为 al,al+1,⋯,ar​。两个非空连续子序列不同,当且仅当下标不同。 例如,当原序列为 [1,2,1,2] 时,要计算子序列 [