0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

Kitronik ARCADE游戏手柄实现连连看

电子森林 来源:硬禾学堂 作者:硬禾学堂 2021-09-08 11:47 次阅读

连连看相信大家都玩过,但这个用Kitronik AR CADE游戏手柄来玩连连看的项目你相信是一个高一学生做的吗?没错,这位来自重庆一所中学的高一学生经过他哥哥的推荐来参加我们的Funpack10期活动,并且他和他哥哥一人设计了一个游戏,属于自己的小游戏。下面就来看看连连看这款小游戏如何设计的吧。

项目链接:https://www.eetree.cn/project/detail/474 ,代码已开源在电子森林。

实现功能

本次FunPack活动可大致分为两个任务

移植或者设计一款游戏

设计一款摩斯密码练习器

在确定参加这期活动之后一直在纠结是按键游戏还是设计摩斯密码练习器,如果按键游戏又在游戏主题上摇摆不定,摩斯密码练习器又感觉是一个很麻烦的任务。恰巧在网络上乱翻时看到了连连看的算法思路,就选定了在Kitronik ARCADE上实现一款连连看游戏。

实现思路及代码介绍

连连看是一种很受大家欢迎的小游戏。下面四张图给出了最基本的消除规则:

f0fceb7e-0fe6-11ec-8fb8-12bb97331649.png

图 A 中出现在同一直线上无障碍的圈圈可以消除;图 B 中两个圈圈可以通过一次转弯消除;图 C 和图 D 中,两个圈圈可以通过两次转弯消除。

由于Kitronik ARCADE的屏幕一次只能完整显示10*7个图块,所以将地图设计为10*7大小。在游戏中使用数组的方式表示地图信息,使用不同的值表示不同的图块,0表示此位置为空,作为一个平面游戏,使用二维数组来保存地图信息最好理解,但由于makecode中函数接口只提供了一维数组。所以只能使用一维数组表示二维信息。创建一个大小为70的一维数组,对于数组中的数据,索引值index/10就是图块行Y的值,index%10即为图块列X的值。

图形显示以及选择实现

对于连连看这款游戏,大家多多少少都知道怎么玩,所以这里不介绍玩法。

一、地图创建以及显示

连连看游戏由不同的图块组成,上面介绍到地图信息确定为大小70的一维数组表示,且不同X、Y坐标位置的数值索引值都已经确定,则这里就会想到通过不同的值表示不同的图块,在游戏中一共使用了7个不同的图块,需要在设置图块地图时添加进入。

1、地图的创建

通过函数InitLevelOneImage,InitLeveTwoImage。。。初始化数组的方式初始化不同关卡地图信息。

2、地图的显示

遍历地图数组

通过索引位置确定图块位置信息

通过数组值将不同的图块放到确定的位置上

二、选择框的移动、消除、更新

1、选择框的创建

创建一个SelectBox对象用于表示选择框,将选择框与左上角第一个图块重叠(图块的大小为16*16,然后地图行列的间隔都是16,所以(8,8)为第一个图块位置)

2、选择框的移动

1)上

判断SelectBox对象是否在第一行(posY = 8),若在第一行则将图块移动到最后一行(第7行,posY = 104),若不在最上一行则直接往上移动一行(将posY减16)

2)下

与向上移动同理,判断SelectBox对象是否在最后一行(第七行,posY = 104),若在最后一行则将图块移动到第一行(posY = 8),若不在第七行则直接往下移动一行(将posY加16)

3)左

判断SelectBox对象是否在第一列(posX= 8),若在第一列则将图块移动到最右一列(第10列,posX = 152),若不在第一列则直接往左移动一列(将posX减16)

4)右

与左移同理,判断SelectBox对象是否在最后一列(第10列,posX= 152),若在最后一列则将图块移动到第一列(posX = 8),若不在最后一列则直接右移一列(将posX加16)

三、选定、取消、消除条件、消除完成判断、关卡更新

游戏中通过A按键选定图块,与选择框类似,只需要A按下时若当前位置不为空,且不为Choice精灵,则在当前选择框的位置创建Choice精灵即可,由于需要选择两个图块,所以A键按下时需要判断是否已经存在了一个Choice精灵(创建ChoiceBoxNums变量表示Choice精灵的数量),若存在则创建第二个Choice精灵,同时运行函数判断是否能被消除。

A按下(选定)

1)判断是否为空

2)若不为空且ChoiceBoxNums == 0时在当前位置创建ChoiceOne精灵,ChoiceBoxNums置1

3)若不为空且ChoiceBoxNums == 1且当前位置不为ChoiceOne位置,则创建ChoiceTwo精灵

消除条件

当ChoiceBoxNums == 2时,表示已经选定了两个图块,此时调用消除函数进行判断与消除。

消除完成判断及关卡更新

当地图数组全为0时表示消除完成,在每次进行判断消除之后进行一次判断是否消除完成,使用遍历数组然后相加的求和的方式得到和,若为0,则表示消除完。若消除完则根据关卡信息决定是进入下一关还是结束游戏。

地图初始化(关卡更新)

更新关卡只需要修改地图数组,然后更改一些特定的值即可完成新地图的载入,Levels表示当前关卡

消除算法

算法参考链接:https://blog.csdn.net/qq_41551359/article/details/82983513,并进行了简单的移植和更改。

设计函数isBlocked 表示x,y位置是否有图块(有无障碍),实现思路为查找数组Y*10+X索引处的值是否为0,若为0则表示此处为空,否则有障碍。

1、水平检测

水平检测用来判断两个点的纵坐标是否相等,同时判断两点间有没有障碍物。

定义函数horizon直接检测两点间是否有障碍物。

先判断A、B是否为同一个点

判断是否为水平关系

确定前后关系

使用循环遍历A、B中间的位格,若有一个为有图块则不能水平消除

2、垂直检测

垂直检测用来判断两个点的横坐标是否相等,同时判断两点间有没有障碍物。

与水平检测原理一致,定义函数vertical直接检测两点之间是否有障碍物

先判断A、B是否为同一个点

判断是否为垂直关系

确定上下关系

使用循环遍历A、B中间的位格,若有一个为有图块则不能水平消除

3、一个拐角检测

一个拐角检测可分解为水平检测和垂直检测,当两个同时满足时,便两点可通过一个拐角相连。即:

一个拐角检测 = 水平检测 && 垂直检测

A 点至 B 点能否连接可转化为满足任意一点:

A 点至 C 点的垂直检测,以及 C 点至 B 点的水平检测;

A 点至 D 点的水平检测,以及 D 点至 B 点的垂直检测。

定义函数 turn_once 用于一个拐角检测

判断A、B两点是否为同一点

判断C(X1,Y2)点是否为空

C、B水平检测&&A、C垂直检测,都满足则返回1

判断D(X2,Y1)是否为空

A、D水平检测&&B、D垂直检测,都满足则返回1

都不满足则返回0,表示不能一个拐点消除

4、两个拐角检测

两个拐角检测可分解为一个拐角检测和水平检测或垂直检测。即:

两个拐角检测 = 一个拐角检测 && (水平检测 || 垂直检测)

水平、垂直分别穿过 A B 共有四条直线,扫描直线上所有不包含 A B 的点,看是否存在一点 C ,满足以下任意一项:

A 点至 C 点通过水平或垂直检测,C 点至 B 点可通过一个拐角连接。(图中用 C 表示)

A 点至 C 点可通过一个拐角连接,C 点至 B 点通过水平或垂直连接。(图中用 C 下划线表示)

创建函数turn_twice用于两个拐角检测:

判断A、B两点是否为同一点

对地图数组进行遍历(temp_x 0-9,temp_y 0-6)

如果C点跟A、B两点都不为水平或者垂直关系,则跳过

若C点坐标为A或者B点,跳过

判断C点是否为空,若为空则跳过

A点与C点做一个拐角检测,C点与B点做水平检测或垂直检测,A、B两点关系都满足则返回1表示C点条件满足

B点与C点做一个拐角检测,C点与A点做水平检测或垂直检测,A、B两点关系都满足则返回1表示C点条件满足

否则返回0

5、算法整合

目前为止,连连看的基本算法都已经实现,整合创建一个remove函数判断相同图块的两点是否能通过以上四种算法消除。

判断两个点是否为同一图块

判断是否能水平消除,若能则将两个位置的数组内容置为0,表示空。

否则判断是否能垂直消除,若能则将两个位置的数组的内容置0

否则判断是否能一个拐点消除,若能则将两个位置的数组值置为0

否则判断两点能否两个拐点消除,若能则将两个位置的数组值置为0

不管是否消除两个图块,销毁两个选择框精灵,将选择框数量变量值置为0

演示说明

游戏开始,游戏地图初始化,开始倒计时。

按下A键选中方块,红框表示方框已选中,然后找到一个与此方块相同的方块,再次选中即可消除。

成功消除第一关全部方块后,自动开始下一关。

在规定时间内消除所有方块即可获胜

如果没有按时消除所有方块就会失败

心得体会

这是我第一次参加Funpack活动,这次活动使我感触很深,青少年可以低成本地通过Funpack的活动认识到游戏编译的乐趣,很有教育意义。

编辑:jq

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • Ar
    Ar
    +关注

    关注

    24

    文章

    5101

    浏览量

    169745
  • 开源
    +关注

    关注

    3

    文章

    3371

    浏览量

    42580
  • 函数
    +关注

    关注

    3

    文章

    4338

    浏览量

    62769
  • 代码
    +关注

    关注

    30

    文章

    4803

    浏览量

    68755
  • cade
    +关注

    关注

    0

    文章

    2

    浏览量

    6276

原文标题:Kitronik ARCADE游戏手柄实现连连看 - Funpack10项目分享二

文章出处:【微信号:xiaojiaoyafpga,微信公众号:电子森林】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    FPGA打砖块小游戏设计思路

    HDL, Vivado 平台上开发打砖块小游戏并使用 PS2 与 VGA 的基本思路: 一、整体架构设计 1. 输入模块: • PS2 接口模块:负责与 PS2 设备(如游戏手柄)进行通信,接收
    的头像 发表于 12-09 16:57 273次阅读

    游戏手柄不可或缺的组件伙计—线性霍尔传感器!

    国产3A游戏大作“黑神话:悟空”的上线,迅速让全网沸腾,收获一大批国内外粉丝,玩家纷纷购买上线试玩,为了方便操作,很多玩家都选择使用游戏手柄来增加游戏可玩性和体验感,那么在这种高帧率的
    的头像 发表于 12-02 15:59 193次阅读
    <b class='flag-5'>游戏</b><b class='flag-5'>手柄</b>不可或缺的组件伙计—线性霍尔传感器!

    线性霍尔元件DH641在游戏手柄中的应用

    线性霍尔元件在游戏手柄中的应用主要体现在提升操控的精确度、稳定性以及耐用性方面,为玩家带来更加优质的游戏体验。以下是对线性霍尔元件在游戏手柄
    的头像 发表于 12-02 14:23 216次阅读

    采用霍尔效应传感器的游戏手柄和控制杆设计

    电子发烧友网站提供《采用霍尔效应传感器的游戏手柄和控制杆设计.pdf》资料免费下载
    发表于 10-30 09:56 0次下载
    采用霍尔效应传感器的<b class='flag-5'>游戏</b><b class='flag-5'>手柄</b>和控制杆设计

    游戏手柄震动马达的技术特点分析

    游戏手柄震动马达在现代电子游戏中扮演着重要的角色,其技术特点直接影响到玩家的游戏体验。游戏手柄
    的头像 发表于 10-09 11:12 391次阅读
    <b class='flag-5'>游戏</b><b class='flag-5'>手柄</b>震动马达的技术特点分析

    基于 FPGA 的飞机大战游戏系统设计

    HDMI 屏,在屏上流畅的显示游戏界面。(3) 游戏手柄驱动模块:驱动手柄上的 PCF8591 芯片,输出摇杆的位置状态。(4) IIC 通信模块:
    发表于 07-24 20:03

    大联大品佳集团推出基于联发科技产品的Wi-Fi 6游戏手柄方案

    2024年6月6日,致力于亚太地区市场的国际领先半导体元器件分销商---大联大控股宣布,其旗下品佳推出基于联发科技(MediaTek)Genio 130A(MT7933)产品的Wi-Fi 6游戏手柄
    的头像 发表于 06-06 13:05 409次阅读
    大联大品佳集团推出基于联发科技产品的Wi-Fi 6<b class='flag-5'>游戏</b><b class='flag-5'>手柄</b>方案

    可编程振荡器,频点22.578MHz,3225封装,应用于红外接收手柄

    游戏手柄中,晶振作为一种常用的频率控制元件,能够产生稳定的脉冲信号,为游戏手柄的电路系统和内部器件提供准确的时序信,一般来说,游戏
    的头像 发表于 05-17 14:07 554次阅读
    可编程振荡器,频点22.578MHz,3225封装,应用于红外接收<b class='flag-5'>手柄</b>

    微软升级Xbox游戏辅助功能,发布Proteus无障碍游戏手柄

    昨日,微软在其Xbox Wire博客发布了关于Proteus游戏手柄的详细资讯,该产品预售价为255美元(约1841元),正式发售后售价299美元(约2159元),预计于2024年秋季交付。
    的头像 发表于 05-16 11:35 441次阅读

    Vision-Board 使用TinyUSB驱动Xbox游戏手柄

    Vision-Board社区有大佬搞新活了!如果手上有XBOX手柄的话赶快掏出你的Vision-Board体验下:接下来看看KunYi大佬如何进行添加的Xbox支持的:准备工作:Vision-Bo
    的头像 发表于 05-11 08:35 482次阅读
    Vision-Board 使用TinyUSB驱动Xbox<b class='flag-5'>游戏</b><b class='flag-5'>手柄</b>

    Vision-Board 使用TinyUSB驱动Xbox游戏手柄

    :  Vision-Board开发板 + 2.0寸Mipi显示屏拓展板  Xbox One游戏手柄  搭建好开发环境:Vision Board 环境搭建 https://docs.qq.com/doc
    的头像 发表于 05-10 15:42 556次阅读
    Vision-Board 使用TinyUSB驱动Xbox<b class='flag-5'>游戏</b><b class='flag-5'>手柄</b>

    超酷!基于ESP32自制一个蓝牙游戏手柄

    通过这个项目,你会学习到如何设计一个面包板游戏手柄电路,学习如何将这个电路作为一个游戏手柄与Android设备、电视盒子、PlayStation和计算机通信。 正文开始!(文末有视频演
    发表于 05-06 16:59

    OpenHarmony南向开发实例:【游戏手柄

    基于TS扩展的声明式开发范式编程语言,以及OpenHarmony的分布式能力实现的一个手柄游戏
    的头像 发表于 04-17 10:21 775次阅读
    OpenHarmony南向开发实例:【<b class='flag-5'>游戏</b><b class='flag-5'>手柄</b>】

    请问stm32H743II usb HOST如何识别双遥杆游戏手柄

    stm32H743II usb HOST 如何识别 双遥杆游戏手柄?北通usb游戏手柄插到PC上显示是XBOX 360手柄
    发表于 03-15 07:52

    华为推出定制游戏手柄专利,满足玩家多样化需求

    据悉,华为的此项专利旨在灵活满足玩家对专属定制手柄的需求,允许用户自主组装、拆卸和重新配置控制器各部分,从而创造符合游戏特定场景及个人喜好的独特武器。
    的头像 发表于 01-31 16:56 887次阅读
    华为推出定制<b class='flag-5'>游戏</b><b class='flag-5'>手柄</b>专利,满足玩家多样化需求