harmonyOS应用组件两种创建方式
1、在layout文件夹中通过xml文件创建
- 创建一个xml文件:例ability_demo.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="#000111"> </DependentLayout>
说明:DependentLayout 标签是所有组件的承载体,所有组件都在该标签里面
- 在DependentLayout标签中插入文本组件
<Text ohos:id="$+id:text" ohos:width="match_content" ohos:height="match_content" ohos:text="你好,鸿蒙" ohos:text_color="#000000" ohos:text_size="32fp" ohos:center_in_parent="true"/>
说明:鸿蒙应用所有组件的属性开始都是ohos:开始的(起始好像是harmonyos:开始,但是我接触的时候是ohos) id(该组件的id),$+id指创建id为text的组件
- 创建DemoAilitySlice.java继承AbilitySlice类,实现onStart方法来加载你定义好的布局:
public class DemoAbilitySlice extends AbilitySlice { @Override public void onStart(Intent intent) { super.onStart(intent); super.setUIContent(ResourceTable.Layout_ability_demo); // 加载xml布局 } }
- 在MainAbility中加载DemoAilitySlice类
public class MainAbility extends Ability { @Override public void onStart(Intent intent) { super.onStart(intent); super.setMainRoute(DemoAbilitySlice.class.getName()); //启动时的第一个页面 } }
2、直接在Slice中创建组件
- 在Slice中创建组件的时候就不用再加载xml文件,直接创建
public void onStart(Intent intent) { super.onStart(intent); // 声明布局 DependentLayout myLayout = new DependentLayout(this); // 设置布局大小 myLayout.setWidth(MATCH_PARENT); myLayout.setHeight(MATCH_PARENT); // 设置布局背景为白色 ShapeElement element = new ShapeElement(); element.setRgbColor(new RgbColor(255, 255, 255)); myLayout.setBackground(element); // 创建一个文本 Text text = new Text(this); text.setText(intent.getStringParam("date")); text.setWidth(MATCH_PARENT); text.setTextSize(100); text.setTextColor(Color.BLACK); // 设置文本的布局 DependentLayout.LayoutConfig textConfig = new DependentLayout.LayoutConfig(MATCH_CONTENT,MATCH_CONTENT); textConfig.addRule(DependentLayout.LayoutConfig.CENTER_IN_PARENT); text.setLayoutConfig(textConfig); myLayout.addComponent(text); //将组件加入到布局页面 super.setUIContent(myLayout); //加载布局 }
小白技术分享
分类:
java技术
标签:
HarmonyOS技术
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix