0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

跨設(shè)備的鴻蒙APP開發(fā)布局及代碼

鴻蒙系統(tǒng)HarmonyOS ? 來源:HarmonyOS技術(shù)社區(qū) ? 作者:androidguy ? 2020-11-03 10:12 ? 次閱讀

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

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

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

"deviceType": [       "tv"     ]

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

"deviceType": [       "tv"     ]

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

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

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

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

public void onStart(Intent intent) {

        super.onStart(intent);
 
        LayoutConfig config = new LayoutConfig(LayoutConfig.MATCH_PARENT,
                                                       LayoutConfig.MATCH_PARENT);
        myLayout.setLayoutConfig(config);
        ShapeElement element = new ShapeElement();
        element.setRgbColor(new RgbColor(255, 255, 255));
        myLayout.setBackground(element);
        Text text = new Text(this);
        text.setLayoutConfig(config);
       text.setText("Hello World");
       text.setTextColor(new Color(0xFF000000));
        text.setTextSize(50);
        text.setTextAlignment(TextAlignment.CENTER);
        myLayout.addComponent(text);
        super.setUIContent(myLayout);
    }

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

if(DeviceInfo.getDeviceType().equals("tv")) { 
    ... ...
} else if(DeviceInfo.getDeviceType().equals("wearable")) {
    ... ...
}


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

public void onStart(Intent intent) {
        super.onStart(intent);
        LayoutConfig config = new LayoutConfig(LayoutConfig.MATCH_PARENT,
                                                       LayoutConfig.MATCH_PARENT);
        myLayout.setLayoutConfig(config);
        ShapeElement element = new ShapeElement();
        element.setRgbColor(new RgbColor(255, 255, 255));
        myLayout.setBackground(element);
        Text text = new Text(this);
        text.setLayoutConfig(config);
        if(DeviceInfo.getDeviceType().equals("tv")) { 
          // 運行在TV上執(zhí)行的代碼
            text.setText("華為智慧屏");
            text.setTextColor(new Color(0xFFFF0000));
            text.setTextSize(200);
        } else if(DeviceInfo.getDeviceType().equals("wearable")) {
            // 運行在Wearable上執(zhí)行的代碼
            text.setText("華為智能手表");
            text.setTextColor(new Color(0xFF0000FF));
            text.setTextSize(50);
        }
        text.setTextAlignment(TextAlignment.CENTER);
        myLayout.addComponent(text);
        super.setUIContent(myLayout);
    }

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

圖2 在TV上顯示的效果

圖3 在Wearable上顯示的效果
編輯:hfy

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 智能手表
    +關(guān)注

    關(guān)注

    36

    文章

    3259

    瀏覽量

    112983
  • 智慧屏
    +關(guān)注

    關(guān)注

    2

    文章

    354

    瀏覽量

    19643
  • HarmonyOS
    +關(guān)注

    關(guān)注

    79

    文章

    1949

    瀏覽量

    29760
收藏 人收藏

    評論

    相關(guān)推薦

    鴻蒙端實踐-布局方案介紹

    封裝到標(biāo)簽中實現(xiàn),業(yè)務(wù)只需要針對標(biāo)簽簡單地設(shè)置相關(guān)屬性,即可實現(xiàn)列表類布局,大幅提升研發(fā)效率。同時動態(tài)化也支持絕對布局以及控制視圖的顯示和隱藏等功能,使之能勝任絕大多數(shù)業(yè)務(wù)布局場景。 在京東金融
    的頭像 發(fā)表于 09-18 10:26 ?667次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>跨</b>端實踐-<b class='flag-5'>布局</b>方案介紹

    鴻蒙開發(fā)者預(yù)覽版如何?

    在24年的華為鴻蒙發(fā)布會中表示。預(yù)覽版已經(jīng)向開發(fā)者開放申請,首批支持的機型有三款分別為華為 Mate 60、華為Mate 60 Pro、華為Mate X5。 其HarmonyOS NEXT去除
    發(fā)表于 02-17 21:54

    如何理解鴻蒙OS是設(shè)備的?

    誰能幫忙解釋鴻蒙OS是怎樣實現(xiàn)平臺的?
    發(fā)表于 09-08 18:17

    【HarmonyOS】開發(fā)設(shè)備鴻蒙(HarmonyOS) App

    設(shè)備單獨開發(fā)App。例如,為手機開發(fā)一款App,為智能電視開發(fā)一款
    發(fā)表于 11-02 15:18

    【HarmonyOS】開發(fā)設(shè)備鴻蒙(HarmonyOS)App

    。例如,為手機開發(fā)一款App,為智能電視開發(fā)一款App,為智能手表開發(fā)一款App。這么做盡管從技
    發(fā)表于 11-03 16:54

    【HarmonyOS】鴻蒙小科普

    中間層,app設(shè)備端分別接入這些kit的sdk。 那么和直接用鴻蒙OS有什么區(qū)別呢? 開發(fā)會上官方給出了答案,不上鴻蒙也是可以實現(xiàn)的,不過
    發(fā)表于 11-04 09:36

    【HarmonyOS】鴻蒙小科普

    中間層,app設(shè)備端分別接入這些kit的sdk。 那么和直接用鴻蒙OS有什么區(qū)別呢? 開發(fā)會上官方給出了答案,不上鴻蒙也是可以實現(xiàn)的,不過
    發(fā)表于 11-04 11:03

    鴻蒙部分科普

    中間層,app設(shè)備端分別接入這些kit的sdk。 那么和直接用鴻蒙OS有什么區(qū)別呢? 開發(fā)會上官方給出了答案,不上鴻蒙也是可以實現(xiàn)的,不過
    發(fā)表于 11-04 13:53

    開發(fā)設(shè)備鴻蒙(HarmonyOS) App

    是可行的,但由于這些不同設(shè)備App,盡管在UI展現(xiàn)上不同,但大多數(shù)邏輯代碼是相同的。如果單獨為不同的設(shè)備開發(fā)
    發(fā)表于 11-13 09:38

    牛掰了!鴻蒙與Android完美融合,將鴻蒙設(shè)備當(dāng)Android設(shè)備

    ,發(fā)現(xiàn)鴻蒙App開發(fā)方式與Android類似,更細(xì)心的小伙伴發(fā)現(xiàn)使用adb devices命令同樣可以得到HarmonyOS模擬器列表,于是就不假思索地認(rèn)為HarmonyOS是Android的套殼
    發(fā)表于 11-13 09:44

    鴻蒙、iOS、安卓的開發(fā)者數(shù)量,APP數(shù)量大對比,差距有多大呢?

    ,只要開發(fā)者數(shù)量多了,APP就多了,生態(tài)就起來了。那么我們對比一下當(dāng)前華為鴻蒙、蘋果iOS、谷歌安卓的開發(fā)者數(shù)量、APP數(shù)量,大家來看一看,
    發(fā)表于 08-30 14:27

    鴻蒙應(yīng)用開發(fā)入門資料合集

    通過XML的方式布局第一張頁面,然后再通過代碼的方式布局第二張頁面。4、鴻蒙應(yīng)用開發(fā)入門資料四:日志HiLog的使用做一個Java攻城師,
    發(fā)表于 03-22 11:23

    請問開發(fā)鴻蒙App的意義在哪里?

    這個問題也可以認(rèn)為是鴻蒙原生App與Android App有什么區(qū)別,如果沒有區(qū)別,本來Android開發(fā)好的應(yīng)用,干嘛還要再去開發(fā)一遍
    發(fā)表于 04-13 11:10

    使用App Game Kit開發(fā)平臺應(yīng)用程序

    了解App Game Kit,一個易于使用的平臺開發(fā)環(huán)境。 用戶可以使用BASIC腳本編寫代碼,也可以使用帶有C ++或XCode的庫。
    的頭像 發(fā)表于 11-06 07:38 ?4191次閱讀

    鴻蒙APP開發(fā)鴻蒙權(quán)限請求框架

    關(guān)于 HarmonyOS 的動態(tài)授權(quán)的常規(guī)操作流程和代碼我之前寫過一篇文章:《鴻蒙動態(tài)權(quán)限申請完整規(guī)范流程和操作詳解》。 文章地址如下: https://harmonyos.51cto.com
    的頭像 發(fā)表于 09-28 09:19 ?2729次閱讀