鴻蒙OS 編寫第一個(gè)頁面

2020-09-17 13:58 更新

在 Java UI 框架中,提供了兩種編寫布局的方式:在XML中聲明UI布局在代碼中創(chuàng)建布局。這兩種方式創(chuàng)建出的布局沒有本質(zhì)差別,為了熟悉兩種方式,我們將通過 XML 的方式編寫第一個(gè)頁面,通過代碼的方式編寫第二個(gè)頁面。

XML 編寫頁面

  1. 在“Project”窗口,打開“entry > src > main > resources > base”,右鍵點(diǎn)擊“base”文件夾,選擇“New > Directory”,命名為“layout”。

img

  1. 右鍵點(diǎn)擊“layout”文件夾,選擇“New > File”,命名為“main_layout.xml”。

img

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

img

  1. 打開“main_layout.xml”文件,添加一個(gè)文本和一個(gè)按鈕,示例代碼如下:

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <DependentLayout
  3. xmlns:ohos="http://schemas.huawei.com/res/ohos"
  4. ohos:width="match_parent"
  5. ohos:height="match_parent"
  6. ohos:background_element="#000000">
  7. <Text
  8. ohos:id="$+id:text"
  9. ohos:width="match_content"
  10. ohos:height="match_content"
  11. ohos:center_in_parent="true"
  12. ohos:text="Hello World"
  13. ohos:text_color="white"
  14. ohos:text_size="32fp"/>
  15. <Button
  16. ohos:id="$+id:button"
  17. ohos:width="match_content"
  18. ohos:height="match_content"
  19. ohos:text_size="19fp"
  20. ohos:text="Next"
  21. ohos:top_padding="8vp"
  22. ohos:bottom_padding="8vp"
  23. ohos:right_padding="80vp"
  24. ohos:left_padding="80vp"
  25. ohos:text_color="white"
  26. ohos:background_element="$graphic:button_element"
  27. ohos:center_in_parent="true"
  28. ohos:align_parent_bottom="true"/>
  29. </DependentLayout>

  1. 上述按鈕的背景是通過“button_element”來顯示的,需要在“base”目錄下創(chuàng)建“graphic”文件夾,在“graphic”文件夾中新建一個(gè)“button_element.xml”文件。

img

button_element.xml”的示例代碼如下:

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

加載 XML 布局

  1. 在“Project”窗口中,選擇“entry> src > main> java > com.example.helloworld > slice” ,打開“MainAbilitySlice.java”文件。

  1. 重寫onStart()方法加載 XML 布局,示例代碼如下:

  1. package com.example.myapplication.slice;
  2. import com.example.myapplication.ResourceTable;
  3. import ohos.aafwk.ability.AbilitySlice;
  4. import ohos.aafwk.content.Intent;
  5. public class MainAbilitySlice extends AbilitySlice {
  6. @Override
  7. public void onStart(Intent intent) {
  8. super.onStart(intent);
  9. super.setUIContent(ResourceTable.Layout_main_layout); // 加載XML布局
  10. }
  11. @Override
  12. public void onActive() {
  13. super.onActive();
  14. }
  15. @Override
  16. public void onForeground(Intent intent) {
  17. super.onForeground(intent);
  18. }
  19. }

  1. 請(qǐng)參考應(yīng)用運(yùn)行,效果如圖所示:

點(diǎn)擊放大

以上內(nèi)容是否對(duì)您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號(hào)
微信公眾號(hào)

編程獅公眾號(hào)