日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
開發(fā)跨設(shè)備的鴻蒙(HarmonyOS)App

想了解更多內(nèi)容,請?jiān)L問:

公司主營業(yè)務(wù):成都網(wǎng)站建設(shè)、成都網(wǎng)站設(shè)計(jì)、移動(dòng)網(wǎng)站開發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實(shí)現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。創(chuàng)新互聯(lián)是一支青春激揚(yáng)、勤奮敬業(yè)、活力青春激揚(yáng)、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊(duì)。公司秉承以“開放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團(tuán)隊(duì)有機(jī)會(huì)用頭腦與智慧不斷的給客戶帶來驚喜。創(chuàng)新互聯(lián)推出阿城免費(fèi)做網(wǎng)站回饋大家。

和華為官方合作共建的鴻蒙技術(shù)社區(qū)

https://harmonyos.

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

當(dāng)然,最簡單,最直接的方式是為每一類智能設(shè)備單獨(dú)開發(fā)App。例如,為手機(jī)開發(fā)一款A(yù)pp,為智能電視開發(fā)一款A(yù)pp,為智能手表開發(fā)一款A(yù)pp。這么做盡管從技術(shù)上是可行的,但由于這些不同設(shè)備的App,盡管在UI展現(xiàn)上不同,但大多數(shù)邏輯代碼是相同的。如果單獨(dú)為不同的設(shè)備開發(fā)App,將會(huì)造成大量的代碼冗余。所以我推薦的方案是讓一個(gè)App同時(shí)適用于不同的智能設(shè)備?;镜脑硎窃贏pp運(yùn)行時(shí)會(huì)自動(dòng)檢測當(dāng)前的設(shè)備,然后會(huì)執(zhí)行與特定設(shè)備相關(guān)的代碼,使用與特定設(shè)備相關(guān)的布局和資源。

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

 
 
 
 
  1. "deviceType": [ "tv" ]

如果創(chuàng)建的是Wearable工程,deviceType屬性的值如下:

 
 
 
 
  1. "deviceType": [ "tv" ]

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

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

當(dāng)完成deviceType屬性的設(shè)置后,當(dāng)前工程就可以同時(shí)在TV和Wearable上運(yùn)行了。不過由于TV和Wearable的屏幕尺寸相差太多,所以布局通常會(huì)采用完全不同的樣式。在HarmonyOS中,可以使用Java語言動(dòng)態(tài)創(chuàng)建組件的方式實(shí)現(xiàn)布局,也可以使用布局文件。關(guān)于布局文件的使用,在后面的文章中會(huì)詳細(xì)介紹。本文主要討論使用Java代碼動(dòng)態(tài)創(chuàng)建組件的布局方式。

在創(chuàng)建的HarmonyOS工程中會(huì)自動(dòng)生成一個(gè)樣例代碼,這些代碼主要集中在MainAbilitySlice.java文件中的onStart方法中,代碼如下:

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

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

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

其中g(shù)etDeviceType方法返回的值就是App當(dāng)前運(yùn)行設(shè)備的類型。如果運(yùn)行在TV上,值為tv,如果運(yùn)行在智能手表上,值為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.           // 運(yùn)行在TV上執(zhí)行的代碼
  13.             text.setText("華為智慧屏");
  14.             text.setTextColor(new Color(0xFFFF0000));
  15.             text.setTextSize(200);
  16.         } else if(DeviceInfo.getDeviceType().equals("wearable")) {
  17.             // 運(yùn)行在Wearable上執(zhí)行的代碼
  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上顯示的文本內(nèi)容、文本尺寸和文本顏色做了改變,所以在TV和Wearable上顯示的文本是不同的。在TV上顯示的效果如圖2所示。在Wearable上顯示的效果如圖3所示。

圖2 在TV上顯示的效果 

圖3 在Wearable上顯示的效果

想了解更多內(nèi)容,請?jiān)L問:

和華為官方合作共建的鴻蒙技術(shù)社區(qū)

https://harmonyos.


新聞標(biāo)題:開發(fā)跨設(shè)備的鴻蒙(HarmonyOS)App
標(biāo)題鏈接:http://www.dlmjj.cn/article/dpspchg.html