经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 移动开发 » 鸿蒙 » 查看文章
鸿蒙开发游戏(一)---大鱼吃小鱼(界面部署)
来源:cnblogs  作者:TMusketeer  时间:2024/2/2 9:09:26  对本文有异议

鸿蒙开发游戏(一)---大鱼吃小鱼(界面部署)

鸿蒙开发游戏(二)---大鱼吃小鱼(摇杆控制)

鸿蒙开发游戏(三)---大鱼吃小鱼(放置NPC)

鸿蒙开发游戏(四)---大鱼吃小鱼(互吃升级)

鸿蒙开发游戏(五)---大鱼吃小鱼(添加音效)

鸿蒙开发游戏(六)---大鱼吃小鱼(称霸海洋)

 

前言:你是否玩过古老而不失优雅的大鱼吃小鱼,小鱼的生存之路何尝不是我们这些打工人的写照,以前想用安卓写的,碰巧鸿蒙它来了,那就边学习边记录吧,这个游戏一共分为6篇,记录了鸿蒙App的第一步创建,申明式UI控件如何使用,简单动画的使用,方法的封装,变量的状态管理,点击事件的分发,页面的生命周期,钩子的使用,一些用法与安卓原生的对比等,也算是一个小完整的项目了。

第一篇相对简单,只是简单的布局摆放,用的知识点是Stack布局,State状态管理,Entry入口,Component注解等

1、创建项目

2、项目结构

3、布局搭建

4、代码编写

 

1、创建项目

一般选择一个空的Ability

我们填写对应的项目名称,Bundle其实相当于安卓的包名,记得IOS也叫Bundle Name,就是唯一的标识。这里选择Api9,因为Api7以前还能使用Java编写,8还可以使用Js编写,到9以后就只能使用ArkTs了,这是官方对ts的一个升级。模型选择Stage,因为Api8以前只有FA模型,这两个模型的区别可以去官方看看,目前你只需要知道用Stage就对了,主推也是Stage模型。

Finish完成

2、项目目录

到这你会发现,系统帮我们创建了entry目录,有一个EntryAbility.ts和Index.ets。

这两个是有关联的,EntryAbility会加载一个主页面作为入口,就是Index.ets,当然你后期新创建了其他ets文件也可以修改。需要注意的是必须要有@Entry和@Component修饰

  • @Entry:作为入口显示
  • @Component:作为组件显示,如我们封装一个通用的TitleView,就只需要此修饰即可。

需要注意的是系统给我们创建了Index.et,会默认给我添加到配置文件中,如果自己创建,需要在这里添加,相当于安卓里的配置文件添加Activity。

3、布局搭建

我们需要2张图,一张小鱼,一张背景图(当然也可以gif,后面的海带飘飘)

放在media目录下,

4、编写代码

  1. @Entry
  2. @Component
  3. export struct FishPage {
  4. build() {
  5. }
  6. }

这是新的一个文件,我取名叫FishPage,我们写的UI 就在build里写,当然这里还有其他的生命周期的方法,这里暂时没用到,后面会一一介绍。

竟然需要背景,那就首选层叠布局Stack

  1. @Entry
  2. @Component
  3. export struct FishPage {
  4. //方向
  5. @State angle: number = 0
  6. //其实位置
  7. @State xFish: number = 100
  8. @State yFish: number = 100
  9. build() {
  10. Row() {
  11. Stack() {
  12. // 背景
  13. Image($r("app.media.bg_fish"))
  14. Image($r("app.media.icon_fish_right"))
  15. .position({ x: this.xFish - 20, y: this.yFish - 20 })
  16. .rotate({ angle: this.angle, centerX: '50%', centerY: '50%' })
  17. .width(40)
  18. .height(40)
  19. Row() {
  20. Button('←')
  21. .onClick(() => {
  22. this.xFish -= 20
  23. })
  24. Column({ space: 40 }) {
  25. Button('↑')
  26. .onClick(()=>{
  27. this.yFish -= 20
  28. })
  29. Button('↓')
  30. .onClick(()=>{
  31. this.yFish += 20
  32. })
  33. }
  34. Button('→')
  35. .onClick(()=>{
  36. this.xFish += 20
  37. })
  38. }
  39. .position({ x: 50, y: 200 })
  40. }
  41. }
  42. }
  43. }

这里需要注意一点就是

  1. Image($r("app.media.bg_fish"))

安卓中是R.drawable.xxx,这里是$r

生命式UI组件的用法这里就不解答了,参考文档很详细

 

第一篇完

 

原文链接:https://www.cnblogs.com/cmusketeer/p/18001520

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号