0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

一招就行—鸿蒙OS 编写第一个页面

王程 来源:jf_75796907 作者:jf_75796907 2024-01-26 18:01 次阅读

Java UI 框架中,提供了两种编写布局的方式:在XML中声明UI布局和在代码中创建布局。这两种方式创建出的布局没有本质差别,为了熟悉两种方式,我们将通过 XML 的方式编写第一个页面,通过代码的方式编写第二个页面。

XML 编写页面

在“Project”窗口,打开“entry > src > main > resources > base”,右键点击“base”文件夹,选择“New > Directory”,命名为“layout”。

wKgaomWzgoyAJOrVAAASymH2WEg447.png

右键点击“layout”文件夹,选择“New > File”,命名为“main_layout.xml”。

wKgZomWzgpaAaca3AAARLEDwkfQ639.png

在“layout”文件夹下可以看到新增了“main_layout.xml”文件。

wKgZomWzgp2Aa7w2AAAR9R6uYrc800.png

打开“main_layout.xml”文件,添加一个文本和一个按钮,示例代码如下:

 < ?xml version="1.0" encoding="utf-8"? >
   < DependentLayout
           xmlns:ohos="http://schemas.huawei.com/res/ohos"
           ohos:width="match_parent"
           ohos:height="match_parent"
           ohos:background_element="#000000" >
       < Text
               ohos:id="$+id:text"
               ohos:width="match_content"
               ohos:height="match_content"
               ohos:center_in_parent="true"
               ohos:text="Hello World"
               ohos:text_color="white"
               ohos:text_size="32fp"/ >
       
   < /DependentLayout >

上述按钮的背景是通过“button_element”来显示的,需要在“base”目录下创建“graphic”文件夹,在“graphic”文件夹中新建一个“button_element.xml”文件。
img

wKgaomWzgraAHQWwAAARO_J3Br0617.png

“button_element.xml”的示例代码如下:

 < ?xml version="1.0" encoding="utf-8"? >
   < shape
           xmlns:ohos="http://schemas.huawei.com/res/ohos"
           ohos:shape="oval" >
       < solid
               ohos:color="#007DFF"/ >
   < /shape >

加载 XML 布局

在“Project”窗口中,选择“entry> src > main> java > com.example.helloworld > slice” ,打开“MainAbilitySlice.java”文件。

重写onStart()方法加载 XML 布局,示例代码如下:

package com.example.myapplication.slice;
    
   import com.example.myapplication.ResourceTable;
   import ohos.aafwk.ability.AbilitySlice;
   import ohos.aafwk.content.Intent;
    
   public class MainAbilitySlice extends AbilitySlice {
    
       @Override
       public void onStart(Intent intent) {
           super.onStart(intent);
           super.setUIContent(ResourceTable.Layout_main_layout); // 加载XML布局
       }
    
       @Override
       public void onActive() {
           super.onActive();
       }
    
       @Override
       public void onForeground(Intent intent) {
           super.onForeground(intent);
       }
   }

请参考应用运行,效果如图所示:

wKgaomWzgsKAJbkKAACP-7PE6kY833.png

审核编辑 黄宇

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • JAVA
    +关注

    关注

    19

    文章

    2958

    浏览量

    104548
  • 鸿蒙OS
    +关注

    关注

    0

    文章

    188

    浏览量

    4368
收藏 人收藏

    评论

    相关推荐

    鸿蒙OS开发:典型页面场景【次开发,多端部署】(设置应用页面

    本小节以“设置”应用页面为例,介绍如何使用自适应布局能力和响应式布局能力适配不同尺寸窗口。
    的头像 发表于 05-27 10:33 1070次阅读
    <b class='flag-5'>鸿蒙</b><b class='flag-5'>OS</b>开发:典型<b class='flag-5'>页面</b>场景【<b class='flag-5'>一</b>次开发,多端部署】(设置应用<b class='flag-5'>页面</b>)

    鸿蒙OS开发:典型页面场景【次开发,多端部署】实战(设置典型页面

    本示例展示了设置应用的典型页面,其在小窗口和大窗口有不同的显示效果,体现次开发、多端部署的能力。
    的头像 发表于 05-27 09:36 1096次阅读
    <b class='flag-5'>鸿蒙</b><b class='flag-5'>OS</b>开发:典型<b class='flag-5'>页面</b>场景【<b class='flag-5'>一</b>次开发,多端部署】实战(设置典型<b class='flag-5'>页面</b>)

    鸿蒙OS开发:【次开发,多端部署】(音乐专辑页面

    基于自适应和响应式布局,实现次开发、多端部署音乐专辑页面
    的头像 发表于 05-25 16:21 730次阅读
    <b class='flag-5'>鸿蒙</b><b class='flag-5'>OS</b>开发:【<b class='flag-5'>一</b>次开发,多端部署】(音乐专辑<b class='flag-5'>页面</b>)

    鸿蒙ArkUI-X跨平台开发:【 编写第一个ArkUI-X应用】

    通过构建简单的ArkUI页面跳转示例,快速了解资源创建引用,路由代码编写和UI布局编写等应用开发流程。
    的头像 发表于 05-21 17:36 639次阅读
    <b class='flag-5'>鸿蒙</b>ArkUI-X跨平台开发:【 <b class='flag-5'>编写</b><b class='flag-5'>第一个</b>ArkUI-X应用】

    鸿蒙OS开发:【次开发,多端部署】( 设置app页面

    本示例展示了设置应用的典型页面,其在小窗口和大窗口有不同的显示效果,体现次开发、多端部署的能力。
    的头像 发表于 05-21 14:56 955次阅读
    <b class='flag-5'>鸿蒙</b><b class='flag-5'>OS</b>开发:【<b class='flag-5'>一</b>次开发,多端部署】( 设置app<b class='flag-5'>页面</b>)

    求助,用CubeMX配置占空比30%的PWM输出第一个波形不准确是为什么?

    我用的是G0的芯片配置,通过抓波发现第一个波形永远与我配置的占空比不准确,但是除了第一个周期不准确外,后面的都没问题。
    发表于 03-18 07:55

    一招教你如何解决管材激光切割机割不透毛边问题

    编辑:镭拓激光管材激光切割机在切割过程中可能会出现割不透或者毛边问题,以下是一招综合性的解决方案:1.检查激光功率:检查激光切割机的功率和激光管的状态。若功率下降或激光管老化,更换激光管或调整激光
    的头像 发表于 03-12 13:17 1138次阅读
    <b class='flag-5'>一招</b>教你如何解决管材激光切割机割不透毛边问题

    鸿蒙页面示例

    @Component 标签修饰UI,相当于Android的view,所有的UI组件都要使用@Component标签 @Entry标签 表明当前是页面,不是
    的头像 发表于 02-01 11:24 430次阅读

    鸿蒙OS和开源鸿蒙什么关系?

    开源鸿蒙(Open Harmony) 鸿蒙系统愿来的设计初衷,就是让所有设备都可以运行系统,但是每个设备的运算能力和功能都不同,所以内核的设计上,采用了微内核的设计,除了最基础的功
    的头像 发表于 01-30 15:44 1084次阅读
    <b class='flag-5'>鸿蒙</b><b class='flag-5'>OS</b>和开源<b class='flag-5'>鸿蒙</b>什么关系?

    鸿蒙开发第一课-各类名词介绍以及基础功能实现

    FA支持Page Ability,Page模板是FA唯支持的模板,用于提供与用户交互的能力。Page实例可以包含组相关页面,每个
    的头像 发表于 01-25 14:32 488次阅读
    <b class='flag-5'>鸿蒙</b>开发<b class='flag-5'>第一</b>课-各类名词介绍以及基础功能实现

    世界上第一个石墨烯半导体的“石墨烯”究竟是什么?

    有媒体报道称有研究团队创造了世界上第一个由石墨烯制成的功能半导体(Functional Graphene Semiconductor)。
    的头像 发表于 01-23 11:26 1150次阅读

    免费学习鸿蒙(HarmonyOS)开发,些地址分享

    国内流高校。通过鸿蒙班的设立,高校可以为学生提供专业的鸿蒙OS学习环境和丰富的实践机会,培养出更多的鸿蒙开发人才,为
    发表于 01-12 20:48

    为何大厂急鸿蒙开发工程师?别有洞天

    正确看待鸿蒙不再兼容安卓版本,而大厂急鸿蒙工程师这举动已经是预料之中的。我们步步来看鸿蒙
    发表于 01-08 19:59

    高频感应加热设备过了保质期不能加热了,联系厂家维修费用高,一招帮你省掉上千块

    高频感应加热设备过了保质期不能加热了,联系厂家维修费用高,一招帮你省掉上千块
    的头像 发表于 12-14 10:23 857次阅读

    哪些晶体、谐振器和振荡器可旋转180°使用?一招儿教你快速识别

    哪些晶体、谐振器和振荡器可旋转180°使用?一招儿教你快速识别
    的头像 发表于 12-05 16:37 374次阅读
    哪些晶体、谐振器和振荡器可旋转180°使用?<b class='flag-5'>一招</b>儿教你快速识别