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

电子说

1.3w人已加入

描述

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

XML 编写页面

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

JAVA

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

JAVA

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

JAVA

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

JAVA

“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

审核编辑 黄宇

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

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分