今日看点

HarmonyOS基础-第一个应用总结

发表于话题:HarmonyOS 2
发布时间:2021-06-02

目录:

HarmonyOS应用项目结构 第一个HarmonyOS应用 下载源码

​​​​​​​

HarmonyOS第一个应用项目

一、HarmonyOS应用项目结构
1.项目结构图
 

 如上图:

 FirstApp为项目名称

External Libraries为一些扩展库或者第三方库,默认就有不需要进行加载
2.项目结构图
  

 gradle:**Gradle**配置文件,由系统自动生成,一般情况下不需要进行修改。

 build: 为编译后生成文件,如最后生成的hap文件(entry-debug-unsigned.hap)

 entry:非常重要,一个项目有且只有一个entry,默认启动模块(主模块),开发者用于编写源码文件以及开发资源文件的目录

 gradle:gradle jar包以及版本信息,可以修改gradle版本,最好使用默认配置

 build.gradle 项目编译配置文件以及第三方库引用等

 gradle.properties gradle属性值,默认是空

 gradlew 是linux gradle命令脚本

 gradlew.bat是windows gradle命令脚本

 local.properties 应用本地属性配置文件,目前只有两个,主要是SDK和nodejs的安装

3.Entry目录结构
 

libs:用于存放entry模块的依赖文件。

src :添加源码的地方

 main 是主要重要的关注的地方,以后就在这个目录畅享你的未来了

 java:用于存放Java源码。

 resources用于存放应用所用到的资源文件,如图形、多媒体、字符串、布局文件等

test 编写代码单元测试代码的目录

config.json:HAP清单文件,详细说明请参考config.json配置文件介绍。

.gitignore:标识git版本管理需要忽略的文件。

build.gradle:entry模块的编译配置文件。

二、第一个HarmonyOS应用
1.项目说明
 1.实现一个XML文件布局(布局中包含一个Button和一个Text组件)

 2.用代码实现一个页面布局(布局中包含一个Button和一个Text组件)

 3.点击Button可以实现两个界面跳转

2.XML布局文件
1.页面布局文件


   
   

组件常用的属性

ohos:height="match_parent" // 组件的高度

ohos:width="match_parent" //组件的宽度

ohos:orientation="vertical" //布局组件的方向属性 适用于DirectionalLayout布局

ohos:id="$+id:text_helloworld" //组件ID,常用Button、Text等组件,用于标识唯一一个组件,便于查找

ohos:text="Hello World" //组件上显示的文本内容,如Button名字或者Text的标签或者文本

ohos:text_size="50fp"

fp:宽度或者高度,距离离,一般描述组件自己的大小(与屏幕密度有关系)

px:描述像素

vp: 宽度或者高度,距离离,一般描述间隔,如内间距,外间距等(与屏幕密度有关系)

ohos:text_color="#55FFFFFF" //文本颜色,55设置透明度, FFFFFF设置的RGB颜色值

ohos:top_padding="8vp" //设置上间距

ohos:bottom_padding="8vp"//设置下间距

ohos:left_padding="8vp"//设置左边距

ohos:right_padding="8vp"//设置右边距

ohos:below="$id:text_helloworld" //设置在文本组件的下方 用于在相对布局中

2.背景布局文件
 background_text



   
   

 background_button



   
   

ohos:shape="rectangle"//背景的图形为矩形
ohos:color="#FF007DFF"//背景的图形颜色
ohos:radius="20"//背景的图形角的弧度
3.Code布局实现

 1.代码实现布局加载

/*创建一个布局,布局中包含一个Text和Button组件*/
/*申明布局并设置布局的大小和背景颜色*/
DependentLayout secondLayout = new DependentLayout(this);
secondLayout.setHeight(MATCH_PARENT);
secondLayout.setWidth(MATCH_PARENT);
ShapeElement element = new ShapeElement();
element.setRgbColor(new RgbColor(55,55,55));
secondLayout.setBackground(element);
/*创建一个Text文本*/
Text text = new Text(this);
text.setText("HarmonyOS第二个页面");
text.setTextSize(20, Text.TextSizeType.FP);
text.setTextColor(Color.CYAN);
text.setId(TEXT_ID);

/*创建一个Button 按钮*/
Button button = new Button(this);
button.setText("上个页面");
button.setTextSize(25, Text.TextSizeType.FP);
button.setTextColor(Color.RED);
button.setPadding(10,10,10,10);
button.setId(BUTTON_ID);
ShapeElement element1 = new ShapeElement();
element1.setRgbColor(new RgbColor(255,55,255));
button.setBackground(element1);
/*设置布局参数*/
DependentLayout.LayoutConfig secondLayoutConfig =
        new DependentLayout.LayoutConfig(MATCH_CONTENT,MATCH_CONTENT);
secondLayoutConfig.addRule(DependentLayout.LayoutConfig.CENTER_IN_PARENT);
text.setLayoutConfig(secondLayoutConfig);
secondLayoutConfig.addRule(DependentLayout.LayoutConfig.BELOW, TEXT_ID);
button.setLayoutConfig(secondLayoutConfig);
secondLayout.addComponent(text);
secondLayout.addComponent(button);
/*将布局添加到Ability*/
super.setUIContent(secondLayout);
4.Button按键事件与界面跳转
1.XML页面Button
/*获取Button 组件*/
Button button = (Button) findComponentById(ResourceTable.Id_button_id);
button.setClickedListener(Componentt->{
    /*添加Button 点击后的处理action*/
    Intent intent1 = new Intent();
    Operation operation = new Intent.OperationBuilder()
            .withDeviceId("")/*设置目标设备的ID ,"" 为本机*/
            .withBundleName("com.example.firstapp")/*指定跳转目标所在的应用包名*/
            .withAbilityName("com.example.firstapp.SecondAbility")/*目标所在的类名*/
            .build();
    intent1.setOperation(operation);
    /*调用一个方法,跳转到SecondAbility adbility*/
    startAbility(intent1);
});
2.Code页面Button
button.setClickedListener(new Component.ClickedListener() {
    @Override
    public void onClick(Component component) {
        Intent intent1 = new Intent();
        Operation operation = new Intent.OperationBuilder()
                .withDeviceId("")
                .withBundleName("com.example.firstapp")
                .withAbilityName("com.example.firstapp.MainAbility")
                .build();
        intent1.setOperation(operation);
        startAbility(intent1);
    }
});
5.java文件说明
 

MyApplication 为项目应用默认入口类
MainAbility 为应用默认加载的Ability类MyApplicationMainAbility为   应用默认加载的Ability类MyApplication中调用
SecondAbility 为添加第二页面增加的ability
MainAbilitySlice 为第一个XML布局加载和显示界面的类
SecondAbilitySlice 为第二页面实现类

 

下载源码

 

作者:czdIT

想了解更多内容,请访问: 51CTO和华为官方战略合作共建的鸿蒙技术社区https://harmonyos.51cto.com

标签组:[按钮

本文来源:https://www.kandian5.com/articles/23934.html

相关阅读

怀孕期间阴道出现褐色分泌物,要尽快就医

阴道分泌物,一般指「白带」,正常呈白色或透明。在孕期出现褐色分泌物,一般是由阴道出血、宫腔胚胎异常或是胎盘异常出血等引起,由于分泌物在阴道停留时间长、排出较晚,就会变成褐色。妊娠期一般分为三个阶段,妊...

2025-10-31

胎梦暗示生女孩?专家拆解梦见小鸟、白色羽毛、晨露含义

自古以来,胎梦就被视为预测胎儿性别和未来发展的重要线索。许多准妈妈在怀孕期间会做各种奇特的梦,其中 梦见小鸟、白色羽毛和晨露 等意象尤为常见,且常被民间解读为可能预示生女孩的征兆。这些梦境究竟蕴含着怎...

2025-10-31

生女孩胎梦大全:梦见花卉、水果、水的预兆与解析!

从古至今,胎梦一直被准父母们视为预测宝宝性别与未来发展的重要线索。本文将深入解析梦见 花卉、水果、水 等常见意象与生女孩之间的神秘联系,为您提供一份详尽的胎梦指南。一、胎梦文化背景与科学认知胎梦,即...

2025-10-31

生女孩胎梦TOP10:月亮、雪花、紫藤花等吉祥梦境盘点

关于生女孩的胎梦,传统解读中往往与 柔和、纯净、优雅的意象 相关联。月亮代表阴柔之美,花朵象征生命的绽放,水元素寓意温柔如水,这些都在文化符号学中与女性特质紧密相连。而现代心理学则认为,这些梦境可能反...

2025-10-31

胎梦里的温柔暗示:梦见月亮、珍珠、蝴蝶大概率生女儿?

在东亚传统文化中,胎梦一直被视为预测胎儿性别和未来命运的重要征兆。当准妈妈们梦见 皎洁的月亮、晶莹的珍珠或翩翩的蝴蝶时,常常会听到"这可能是怀女孩的征兆"的说法。这些美丽而温柔的梦境意象,为何会与女孩...

2025-10-31

生女孩胎梦科学吗?心理学+民间说法双角度解析梦见蝴蝶

在备孕和怀孕期间,许多准父母都会经历各种奇妙的梦境,其中 "梦见蝴蝶" 常被认为与生女孩有关。这种关联不仅存在于中国民间传统中,在世界各地的文化里也有着丰富的解读。本文将从 心理学科学视角 和 民间传...

2025-10-31

生女孩胎梦VS生男孩胎梦:5大关键区别,你梦对了吗?

自古以来,胎梦就被视为预测胎儿性别和未来发展的重要征兆。许多准父母在怀孕期间都会经历各种生动奇特的梦境,这些梦境往往被赋予特殊的含义。在传统文化中, 生女孩和生男孩的胎梦有着显著的区别 ,从梦境内容到...

2025-10-31

社区医生:怀孕别养猫了,二手烟反倒没事!孕妇无语了

河南有一个孕妈妈怀孕五周去社区医院做阴道B超,确定自己有没有怀孕。当时夫妻俩想到怀孕了都非常关注,所以两夫妻都去医院了。而这个孕妈妈的老公有吸烟的习惯,她就希望能跟医生说一下,让老公戒烟,而且她家里面...

2025-10-31

男人抽烟对家庭伤害多大?老婆流产,女儿肺癌,儿子身高少10厘米

虽然每一包香烟上面都写着‘吸烟有害健康’,但是抽烟的人感受到的是烟可以带给他快乐。比如饭后抽一根烟就感觉自己像是神仙一样;比如说在困的时候抽一根烟能够解乏;比如说在无聊的时候抽...

2025-10-31

宝宝摔下床后,别急着立刻扶起来,了解"黄金十秒"很重要

广东中山一位宝妈面对孩子头朝下摔下床后的做法在短视频平台获得了众多网友的称赞。一是她没有慌乱;二是处理方法十分科学,连不少专家都留言夸赞“妈妈的做法让孩子受到的伤害降到最低”、...

2025-10-31