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

  1. 在“Project”窗口,点击“entry > src > main > resources > base > layout”,打开“ability_main.xml”文件。

  1. 在“ability_main.xml”文件中创建一个文本和一个按钮,示例代码如下:
    1. <?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="#FFFFFF">
          <Text
              ohos:id="$+id:text"
              ohos:width="match_content"
              ohos:height="match_content"
              ohos:text="Hello World"
              ohos:text_color="#000000"
              ohos:text_size="32fp"
              ohos:center_in_parent="true"/>
          <Button
              ohos:id="$+id:button"
              ohos:width="match_content"
              ohos:height="match_content"
              ohos:text="Next"
              ohos:text_size="19fp"
              ohos:text_color="#FFFFFF"
              ohos:top_padding="8vp"
              ohos:bottom_padding="8vp"
              ohos:right_padding="70vp"
              ohos:left_padding="70vp"
              ohos:background_element="$graphic:background_button"
              ohos:center_in_parent="true"
              ohos:align_parent_bottom="true"
              ohos:bottom_margin="40vp"/>
      </DependentLayout>
  2. 上述按钮的背景是通过“background_button”来显示的。右键点击“graphic”文件夹,选择“New > File”,命名为“background_button.xml”。

“background_button.xml”的示例代码如下(如果DevEco Studio提示xmlns字段错误,请忽略,不影响后续操作):

<?xml version="1.0" encoding="utf-8"?>
<shape
    xmlns:ohos="http://schemas.huawei.com/res/ohos"
    ohos:shape="rectangle">
    <corners
        ohos:radius="100"/>
    <solid
        ohos:color="#007DFF"/>
</shape>
  1. 在“Project”窗口,选择“entry > src > main > java > com.example.myapplication > slice” ,打开“MainAbilitySlice.java”文件,使用setUIContent方法加载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_ability_main); // 加载XML布局
        }
     
        @Override
        public void onActive() {
            super.onActive();
        }
     
        @Override
        public void onForeground(Intent intent) {
            super.onForeground(intent);
        }
    }
    

说明:如果DevEco Studio提示Layout_ability_main错误,点击菜单栏的“Build”,选择“Build App(s)/Hap(s) > Build Debug Hap(s) ”,即可消除报错。

想入门鸿蒙开发又怕花冤枉钱?别错过!现在能免费系统学 -- 从 ArkTS 面向对象核心的类和对象、继承多态,到吃透鸿蒙开发关键技能,还能冲刺鸿蒙基础 +高级开发者证书,更惊喜的是考证成功还送好礼!快加入我的鸿蒙班,一起从入门到精通,班级链接:点击免费进入

Logo

作为“人工智能6S店”的官方数字引擎,为AI开发者与企业提供一个覆盖软硬件全栈、一站式门户。

更多推荐