在 Java UI 框架中,提供了两种编写布局的方式:在XML中声明UI布局和在代码中创建布局。这两种方式创建出的布局没有本质差别,为了熟悉两种方式,我们将通过 XML 的方式编写第一个页面,通过代码的方式编写第二个页面。
XML 编写页面
在“Project”窗口,打开“entry > src > main > resources > base”,右键点击“base”文件夹,选择“New > Directory”,命名为“layout”。

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

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

打开“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

“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); } }
请参考应用运行,效果如图所示:

审核编辑 黄宇
-
JAVA
+关注
关注
20文章
3015浏览量
117030 -
鸿蒙OS
+关注
关注
0文章
194浏览量
5581
发布评论请先 登录
IT 补丁管理的8大深坑,一招全破解
开源鸿蒙6.1 Release版本正式发布,在鸿OS 6.1率先完成升级适配!
智能楼宇改造避坑指南:别再换掉所有老设备!一招搞定ETHERNET/IP转DEVICENET的共存难题
以龙企招为例,浅谈鸿蒙应用开发者激励计划 2025 参与心得
Linux 下交叉编译实战:跑起来你的第一个 STM32 程序
**CW32L012****开发评估板的第一个程序**
DIY 流体模拟吊坠(一):理论与第一个吊坠的制作
工业电路总出问题?槟城BMG10D系列压敏复合器件:一招解决过压难题
小白也能轻松上手!一招解决IP被封杀难题
知乎开源“智能预渲染框架” 几行代码实现鸿蒙应用页面“秒开”
【HarmonyOS 5】鸿蒙页面和组件生命周期函数
一招解决多地区无感考勤的问题
HarmonyOS实战:一招搞定保存图片到相册
HarmonyOS实战:一招解决等待多个并发结果
一招就行—鸿蒙OS 编写第一个页面
评论