鸿蒙开发入门实战案例-五子棋游戏(附源码)_鸿蒙围棋定式案例,HarmonyOS鸿蒙学习心得

172 阅读6分钟

我说的再简单一点,棋子的落点范围只能在红色框内的十字上,且每一个格子和棋子的大小都是24,所以,我以红框的左上角为原点,只要棋子的x坐标和y坐标都是24的倍数,就能准确的落在十字上。所以上面的代码要改一下position:

然后我们要给Stack容器添加点击事件,获取点击的坐标,并在点击的位置添加棋子。有一个问题,我们很难做到每一次都准确的点击到十字中间,所以获取到的坐标要对24取整,得到的值乘以24就是最近的十字格,然后把得到的坐标存入数组,界面上使用Foreach循环渲染即可。

let x = event.screenX - parseFloat(event.target.area.globalPosition.x.toString()) let y = event.screenY - parseFloat(event.target.area.globalPosition.y.toString()) let xv = x/24 let yv = y/24 let areaChess = { 'x': parseInt(xv.toString()), 'y': parseInt(yv.toString()) } if(this.blackTurns){ this.blackChesses.push(areaChess) }else { this.whiteChesses.push(areaChess) }

界面布局完成之后,真正的难点来了,怎么判断棋盘上有没有五子连珠?

强调一下,我刚才存入数组的是棋子的坐标,24的倍数,举个例子:

白棋: [ {'x':10,'y':5}, {'x':3,'y':4}, {'x':2,'y':3}, {'x':7,'y':7}, ]

黑棋: [ {'x':9,'y':4}, {'x':5,'y':6}, {'x':4,'y':3}, {'x':8,'y':6}, ]

某一方要完成五子连线的话,首先棋子数要达到5,然后我把棋子数组以x值进行从小到大排序。这样的话我再去遍历数组,五子连线只存在以下几种情况:

可以总结出规律:连成线的五颗棋子x值要么相等,要么是连续的5个数字,并且对应的y值也是这样。这样算法就不难写了:

//排序 this.sortarr = this.sortarr.sort(function (a: Object, b: Object) { return a['x'] - b['x']; }); //遍历 for(let i=0;i<this.sortarr.length - 4;i++){ let item1 = this.sortarr[i] let item2 = this.sortarr[i+1] let item3 = this.sortarr[i+2] let item4 = this.sortarr[i+3] let item5 = this.sortarr[i+4]

let x1 = item1['x']; let x2 = item2['x']; let x3 = item3['x']; let x4 = item4['x']; let x5 = item5['x'];

let y1 = item1['y']; let y2 = item2['y']; let y3 = item3['y']; let y4 = item4['y']; let y5 = item5['y'];

if(x2-x1 == x3-x2 && x4-x3 == x2-x1 && x5-x4 == x2-x1 && x2-x1<2){ if(y2-y1 == y3-y2 && y4-y3 == y2-y1 && y5-y4 == y2-y1 && y2-y1<2 && y2-y1>-2 ){ if(isBlack){ console.log("黑棋赢了!!!!!!!!!") }else { console.log("白棋赢了!!!!!!!!!") }

} } }

搞定了,就这么简单。需要此次完整源码,请点击下方链接获取

最后,有很多小伙伴不知道学习哪些鸿蒙开发技术?不知道需要重点掌握哪些鸿蒙应用开发知识点?而且学习时频繁踩坑,最终浪费大量时间。所以有一份实用的鸿蒙(Harmony NEXT)资料用来跟着学习是非常有必要的。 

这份鸿蒙(Harmony NEXT)资料包含了鸿蒙开发必掌握的核心知识要点,内容包含了(**ArkTS、ArkUI开发组件、Stage模型、多端部署、分布式应用开发、音频、视频、WebGL、OpenHarmony****多媒体技术、Napi组件、OpenHarmony内核、Harmony南向开发、鸿蒙项目实战等等)鸿蒙(Harmony NEXT)**技术知识点。

希望这一份鸿蒙学习资料能够给大家带来帮助,有需要的小伙伴自行领取,限时开源,先到先得~无套路领取!!

如果你是一名有经验的资深Android移动开发、Java开发、前端开发、对鸿蒙感兴趣以及转行人员,可以直接领取这份资料

获取这份完整版高清学习路线,请点击→纯血版全套鸿蒙HarmonyOS学习资料****

鸿蒙(Harmony NEXT)最新学习路线

  • HarmonOS基础技能

  • HarmonOS就业必备技能 
  • HarmonOS多媒体技术

  • 鸿蒙NaPi组件进阶

  • HarmonOS高级技能

  • 初识HarmonOS内核
  • 实战就业级设备开发

有了路线图,怎么能没有学习资料呢,小编也准备了一份联合鸿蒙官方发布笔记整理收纳的一套系统性的鸿蒙(OpenHarmony )学习手册(共计1236页)鸿蒙(OpenHarmony )开发入门教学视频,内容包含:ArkTS、ArkUI、Web开发、应用模型、资源分类…等知识点。

获取以上完整版高清学习路线,请点击→纯血版全套鸿蒙HarmonyOS学习资料

《鸿蒙 (OpenHarmony)开发入门教学视频》

《鸿蒙生态应用开发V2.0白皮书》

图片

《鸿蒙 (OpenHarmony)开发基础到实战手册》

OpenHarmony北向、南向开发环境搭建

图片

《鸿蒙开发基础》

  • ArkTS语言
  • 安装DevEco Studio
  • 运用你的第一个ArkTS应用
  • ArkUI声明式UI开发
  • .……

图片

《鸿蒙开发进阶》

  • Stage模型入门
  • 网络管理
  • 数据管理
  • 电话服务
  • 分布式应用开发
  • 通知与窗口管理
  • 多媒体技术
  • 安全技能
  • 任务管理
  • WebGL
  • 国际化开发
  • 应用测试
  • DFX面向未来设计
  • 鸿蒙系统移植和裁剪定制
  • ……

图片

《鸿蒙进阶实战》

  • ArkTS实践

img img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!