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


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

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

    鸿蒙开发游戏(三)---大鱼吃小鱼(放置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、编写代码

    @Entry
    @Component
    export struct FishPage {
        
      build() {
    
      }
    }

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

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

    @Entry
    @Component
    export struct FishPage {
      //方向
      @State angle: number = 0
      //其实位置
      @State xFish: number = 100
      @State yFish: number = 100
    
      build() {
        Row() {
          Stack() {
            // 背景
            Image($r("app.media.bg_fish"))
    
            Image($r("app.media.icon_fish_right"))
              .position({ x: this.xFish - 20, y: this.yFish - 20 })
              .rotate({ angle: this.angle, centerX: '50%', centerY: '50%' })
              .width(40)
              .height(40)
    
    
            Row() {
              Button('←')
                .onClick(() => {
                  this.xFish -= 20
                })
              Column({ space: 40 }) {
                Button('↑')
                  .onClick(()=>{
                    this.yFish -= 20
                  })
                Button('↓')
                  .onClick(()=>{
                    this.yFish += 20
                  })
              }
    
              Button('→')
                .onClick(()=>{
                  this.xFish += 20
                })
            }
            .position({ x: 50, y: 200 })
          }
        }
      }
    }

    这里需要注意一点就是

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

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

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

     

    第一篇完

     

  • 相关阅读:
    JVM 输出 GC 日志导致 JVM 卡住,我 TM 人傻了
    logback通过EvaluatorFilter实现同时记录多个level级别的日志
    一文了解 Go 方法
    操作系统——中断
    头歌-信息安全技术-【实训10】HTML信息隐藏、动态分析技术
    【后端】初识HTTP_2
    【BOOST C++ 12 函数式编程】(4) Boost.Ref
    Openfoam UPstream类探索(一)
    AI内容生成时代:该如何和AI对话?
    1358:中缀表达式值(expr)
  • 原文地址:https://www.cnblogs.com/cmusketeer/p/18001520