今日看点

HarmonyOs基础

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

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 为第二页面实现类

源码
链接:https://pan.baidu.com/s/1JHcX_S7Ju6MdntsINlI2PA
提取码:1tqx

标签组:[按钮

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

相关阅读

韩剧《Crash》第1-12全集剧情(含结局)

韩剧《Crash》(碰撞搜查线)讲述无人关注的交通犯罪调查组展开横冲直撞的犯罪追踪故事,该剧是韩国首部以交通犯罪为主要题材的电视剧。韩剧《Crash》第1集分集剧情交通犯罪调查组(TCI)是一支由四...

2024-05-20

感情太好了!都暻秀自曝和好友李光洙一起去医院体检

近日,艺人都暻秀与导演罗英锡两人一起进行了网络直播,在直播中都暻秀谈及了与演员李光洙之间的有趣故事,引发了网友们的热议。众所周知,在韩娱有很多艺人小圈子,都暻秀和李光洙就是其中一个小圈子,他们这个...

2024-05-20

《狐妖小红娘月红篇》定档5月23日 杨幂龚俊涂山结缘上演唯美妖凡恋

由爱奇艺、阅文影视、恒星引力联合出品,恒星引力制作,爱奇艺桃乐奇工作室打造,龚宇、侯晓楠、王一栩、张宇成担任出品人,王晓晖、侯晓楠、林珊担任总监制,戴莹、王一栩、张宇成担任总制片人,麦贯之、杜林执导,...

2024-05-20

《庆余年2》大结局

最近热播的《庆余年2》,在播出后立刻引起了轰动,不仅吸引了大量观众的目光,也俘获了不少粉丝的心。其中关于《庆余年2》大结局无疑是最近大家最关注的,今天我们就一起来讨论讨论。《庆余年2》大结局结局是庆帝...

2024-05-20

《庆余年2》陈萍萍身份曝光 陈萍萍被怎样羞辱?

《庆余年2》陈萍萍身份曝光:陈萍萍,身份卓然的庆国监察院院长,他的一生如同巍峨的山峰,屹立不摇。在庆国的繁华和阴谋交织的舞台上,陈萍萍的身份既是庆帝的亲信太监,更是范闲的师父和朋友。他的传奇故事,集智...

2024-05-20

泰剧《日暮情深》每周更新几集

目前,正在热播的《日暮情深》无论从演员的颜值还是演技以及剧情等方面都已经吸引了许多观众的关注。其中,针对泰剧《日暮情深》每周更新几集的讨论也是一直不断,现在,我们就来看一下这个观众最为关心的话题。 泰...

2024-05-20

【爱盘点】人气动漫《鬼灭之刃》中九柱有哪些?战力又如何?

人气动漫《鬼灭之刃》可以说是这几年风靡全球的热血动漫了,在一众漫画中一骑绝尘,不仅动画世界范围内大爆,漫画销量也突破了1.5亿册,着实是火爆。目前,该漫画的动画作品《鬼灭之刃柱训练篇》也正式推出,...

2024-05-20

汪峰官宣恋情,展现担当与真诚,网友点赞“好男人”

在娱乐圈中,汪峰的名字总是和音乐紧密相连,而今天,他再次成为焦点,不过这次是因为他的个人生活。汪峰在社交媒体上正式宣布与网红森林北的恋情,同时对近期关于他的婚内出轨谣言进行了坚决而有力的回击。汪峰在官...

2024-05-20

《我们仨》涠洲岛环岛之旅 观山看海一样都不少

旅行探索真人秀节目《我们仨》正在湖南卫视、芒果TV热播中。第九期节目中,郭麒麟、毛不易、魏大勋以及飞行嘉宾秦霄贤深入探索北海涠洲岛,带领观众们开启了一场自由且治愈的海岛之行,在远离尘嚣的生活中感受无忧...

2024-05-20

《2024中国诗词大会》圆满收官 我们一直“在路上”

中华诗词如万古江河,有多少光辉的诗篇,就有多少为了远方的“在路上”。“路漫漫其修远兮,吾将上下而求索”,在爱国的路上,忠诚升华为信仰;“踏遍青山人未老,风景这边独好”,在征战的路上,山川都迸发出激昂;...

2024-05-20