成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

開發跨設備的鴻蒙(HarmonyOS)App

開發 前端 OpenHarmony
現在的智能設備種類越來越多,而且這些智能設備的屏幕尺寸、分辨率都不同,這就給開發App帶來了麻煩。現在幾乎每一個智能設備廠商,如Apple、華為都面臨這個問題。這就要求我們開發的App盡可能適合更多的智能設備。

想了解更多內容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術社區

https://harmonyos.51cto.com

 現在的智能設備種類越來越多,而且這些智能設備的屏幕尺寸、分辨率都不同,例如,比較常見的智能設備有手機、平板電腦、車載電腦、智能電視、智能手表等。盡管這些設備都有屏幕,但它們的屏幕千差萬別,有的屏幕尺寸小,有的屏幕尺寸大,有的是縱向的屏幕,有的是橫向的屏幕,有的帶觸摸功能,有的不帶觸摸功能,甚至有的設備的屏幕是圓形(如智能手表),這就給開發App帶來了麻煩。現在幾乎每一個智能設備廠商,如Apple、華為都面臨這個問題。這就要求我們開發的App盡可能適合更多的智能設備。

當然,最簡單,最直接的方式是為每一類智能設備單獨開發App。例如,為手機開發一款App,為智能電視開發一款App,為智能手表開發一款App。這么做盡管從技術上是可行的,但由于這些不同設備的App,盡管在UI展現上不同,但大多數邏輯代碼是相同的。如果單獨為不同的設備開發App,將會造成大量的代碼冗余。所以我推薦的方案是讓一個App同時適用于不同的智能設備。基本的原理是在App運行時會自動檢測當前的設備,然后會執行與特定設備相關的代碼,使用與特定設備相關的布局和資源。

這里的關鍵點是檢測當前的設備類型。在創建HarmonyOS工程時,要么創建TV(華為智慧屏)工程,要么創建Wearable(智能手表)工程,所以使用模板創建的HarmonyOS工程只能在一類設備(TV或Wearable)中運行。讀者可以通過config.json文件的deviceType屬性查看當前工程可以運行的設備類型,如果創建的是TV工程,deviceType屬性的值如下: 

  1. "deviceType": [ "tv" ] 

如果創建的是Wearable工程,deviceType屬性的值如下:

  1. "deviceType": [ "tv" ] 

如果deviceType屬性的值是tv,當前工程是不能在智能手表上運行的,反之亦然。要想讓當前工程同時在TV和Wearable上運行,需要同時指定tv和wearable(要手動修改config.json文件),配置代碼如下:

  1. "deviceType": [ "tv""wearable" ] 

當完成deviceType屬性的設置后,當前工程就可以同時在TV和Wearable上運行了。不過由于TV和Wearable的屏幕尺寸相差太多,所以布局通常會采用完全不同的樣式。在HarmonyOS中,可以使用Java語言動態創建組件的方式實現布局,也可以使用布局文件。關于布局文件的使用,在后面的文章中會詳細介紹。本文主要討論使用Java代碼動態創建組件的布局方式。

在創建的HarmonyOS工程中會自動生成一個樣例代碼,這些代碼主要集中在MainAbilitySlice.java文件中的onStart方法中,代碼如下:

  1. public void onStart(Intent intent) { 
  2.  
  3.         super.onStart(intent); 
  4.   
  5.         LayoutConfig config = new LayoutConfig(LayoutConfig.MATCH_PARENT, 
  6.                                                        LayoutConfig.MATCH_PARENT); 
  7.         myLayout.setLayoutConfig(config); 
  8.         ShapeElement element = new ShapeElement(); 
  9.         element.setRgbColor(new RgbColor(255, 255, 255)); 
  10.         myLayout.setBackground(element); 
  11.         Text text = new Text(this); 
  12.         text.setLayoutConfig(config); 
  13.        text.setText("Hello World"); 
  14.        text.setTextColor(new Color(0xFF000000)); 
  15.         text.setTextSize(50); 
  16.         text.setTextAlignment(TextAlignment.CENTER); 
  17.         myLayout.addComponent(text); 
  18.         super.setUIContent(myLayout); 
  19.     } 

讀者并不需要對這段代碼的每一行都了解,只需要知道這段代碼將背景設為白色,并且在創建了一個用于顯示文本的Text組件,并且在屏幕中心顯示Hello World。如果在TV設備上運行,效果如圖1所示。不過這樣以來,在所有的設備中的UI都一樣,但我們的目的是讓不同的設備顯示不同的UI,所以就需要通過下面的代碼判斷當前設備的類型。

  1. if(DeviceInfo.getDeviceType().equals("tv")) {  
  2.     ... ... 
  3. else if(DeviceInfo.getDeviceType().equals("wearable")) { 
  4.     ... ... 

 

其中getDeviceType方法返回的值就是App當前運行設備的類型。如果運行在TV上,值為tv,如果運行在智能手表上,值為wearable。所以可以用下面的代碼來替換onStart方法中的代碼。

  1. public void onStart(Intent intent) { 
  2.         super.onStart(intent); 
  3.         LayoutConfig config = new LayoutConfig(LayoutConfig.MATCH_PARENT, 
  4.                                                        LayoutConfig.MATCH_PARENT); 
  5.         myLayout.setLayoutConfig(config); 
  6.         ShapeElement element = new ShapeElement(); 
  7.         element.setRgbColor(new RgbColor(255, 255, 255)); 
  8.         myLayout.setBackground(element); 
  9.         Text text = new Text(this); 
  10.         text.setLayoutConfig(config); 
  11.         if(DeviceInfo.getDeviceType().equals("tv")) {  
  12.           // 運行在TV上執行的代碼 
  13.             text.setText("華為智慧屏"); 
  14.             text.setTextColor(new Color(0xFFFF0000)); 
  15.             text.setTextSize(200); 
  16.         } else if(DeviceInfo.getDeviceType().equals("wearable")) { 
  17.             // 運行在Wearable上執行的代碼 
  18.             text.setText("華為智能手表"); 
  19.             text.setTextColor(new Color(0xFF0000FF)); 
  20.             text.setTextSize(50); 
  21.         } 
  22.         text.setTextAlignment(TextAlignment.CENTER); 
  23.         myLayout.addComponent(text); 
  24.         super.setUIContent(myLayout); 
  25.     } 

在這段代碼中,將TV和Wearable上顯示的文本內容、文本尺寸和文本顏色做了改變,所以在TV和Wearable上顯示的文本是不同的。在TV上顯示的效果如圖2所示。在Wearable上顯示的效果如圖3所示。

 

圖2 在TV上顯示的效果 
 

圖3 在Wearable上顯示的效果

想了解更多內容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術社區

https://harmonyos.51cto.com

【編輯推薦】

 

責任編輯:jianghua 來源: 鴻蒙社區
相關推薦

2021-01-06 11:21:56

鴻蒙HarmonyOS應用開發

2022-11-18 15:42:36

2021-02-03 09:59:02

鴻蒙HarmonyOS應用開發

2021-06-23 15:48:08

鴻蒙HarmonyOS應用

2021-01-14 09:50:26

鴻蒙HarmonyOSAPP

2022-05-19 15:40:37

配網開發設備開發

2021-01-06 10:59:14

鴻蒙HarmonyOSPage Abilit

2020-11-11 11:56:05

HarmonyOS

2021-06-16 15:18:03

鴻蒙HarmonyOS應用

2021-03-23 09:52:39

鴻蒙HarmonyOS應用開發

2022-08-06 08:34:04

京東App適配技術棧

2021-03-29 09:59:09

鴻蒙HarmonyOS應用開發

2021-01-18 13:17:04

鴻蒙HarmonyOSAPP

2021-07-08 09:42:04

鴻蒙HarmonyOS應用

2022-05-18 16:17:31

設備開發鴻蒙

2020-09-28 15:13:04

鴻蒙

2021-06-24 09:32:00

鴻蒙HarmonyOS應用

2022-05-06 15:38:21

鴻蒙App開發技術

2014-09-26 22:21:33

2015-09-24 14:25:00

SublimeAPICloudAPP
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久久久国产精品午夜一区 | 国产激情综合五月久久 | 国产欧美视频一区二区三区 | 亚洲高清视频一区二区 | 天天爽综合网 | 毛片视频免费观看 | 午夜影院污 | 国产精品视频久久久 | 欧美xxxx日本 | 欧美福利影院 | 久久久久久久久淑女av国产精品 | 91麻豆精品国产91久久久久久久久 | 日韩欧美一区二区三区免费观看 | 免费久久视频 | 欧美黄色片 | www.yw193.com| 一区二区三区免费 | 欧美性精品 | 国产精品69久久久久水密桃 | 欧美视频在线播放 | 国产成人a亚洲精品 | 午夜天堂精品久久久久 | 成人美女免费网站视频 | 操操操日日日 | 涩涩视频在线观看 | 日本精品一区二区在线观看 | 天天草天天操 | 在线视频中文字幕 | 国产一区二区在线视频 | 91爱爱·com | 亚洲日日夜夜 | 99爱在线观看| 久久综合伊人 | 国产高清久久 | 国产精品视频网 | 99爱免费| 亚洲一区国产精品 | 亚洲精品自拍 | 一区二区三区中文字幕 | 国产精品成人一区二区 | 高清黄色网址 |