0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看威廉希尔官方网站 视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

跨设备的鸿蒙APP开发布局及代码

鸿蒙系统HarmonyOS 来源:HarmonyOS威廉希尔官方网站 社区 作者:androidguy 2020-11-03 10:12 次阅读

现在的智能设备种类越来越多,而且这些智能设备的屏幕尺寸、分辨率都不同,例如,比较常见的智能设备有手机、平板电脑、车载电脑、智能电视、智能手表等。尽管这些设备都有屏幕,但它们的屏幕千差万别,有的屏幕尺寸小,有的屏幕尺寸大,有的是纵向的屏幕,有的是横向的屏幕,有的带触摸功能,有的不带触摸功能,甚至有的设备的屏幕是圆形(如智能手表),这就给开发App带来了麻烦。现在几乎每一个智能设备厂商,如Apple、华为都面临这个问题。这就要求我们开发的App尽可能适合更多的智能设备。

当然,最简单,最直接的方式是为每一类智能设备单独开发App。例如,为手机开发一款App,为智能电视开发一款App,为智能手表开发一款App。这么做尽管从威廉希尔官方网站 上是可行的,但由于这些不同设备的App,尽管在UI展现上不同,但大多数逻辑代码是相同的。如果单独为不同的设备开发App,将会造成大量的代码冗余。所以我推荐的方案是让一个App同时适用于不同的智能设备。基本的原理是在App运行时会自动检测当前的设备,然后会执行与特定设备相关的代码,使用与特定设备相关的布局和资源。

这里的关键点是检测当前的设备类型。在创建HarmonyOS工程时,要么创建TV(华为智慧屏)工程,要么创建Wearable(智能手表)工程,所以使用模板创建的HarmonyOS工程只能在一类设备(TV或Wearable)中运行。读者可以通过config.json文件的deviceType属性查看当前工程可以运行的设备类型,如果创建的是TV工程,deviceType属性的值如下:

"deviceType": [       "tv"     ]

如果创建的是Wearable工程,deviceType属性的值如下:

"deviceType": [       "tv"     ]

如果deviceType属性的值是tv,当前工程是不能在智能手表上运行的,反之亦然。要想让当前工程同时在TV和Wearable上运行,需要同时指定tv和wearable(要手动修改config.json文件),配置代码如下:

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

当完成deviceType属性的设置后,当前工程就可以同时在TV和Wearable上运行了。不过由于TV和Wearable的屏幕尺寸相差太多,所以布局通常会采用完全不同的样式。在HarmonyOS中,可以使用Java语言动态创建组件的方式实现布局,也可以使用布局文件。关于布局文件的使用,在后面的文章中会详细介绍。本文主要讨论使用Java代码动态创建组件的布局方式。

在创建的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);
    }

读者并不需要对这段代码的每一行都了解,只需要知道这段代码将背景设为白色,并且在创建了一个用于显示文本的Text组件,并且在屏幕中心显示Hello World。如果在TV设备上运行,效果如图1所示。不过这样以来,在所有的设备中的UI都一样,但我们的目的是让不同的设备显示不同的UI,所以就需要通过下面的代码判断当前设备的类型。

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


其中getDeviceType方法返回的值就是App当前运行设备的类型。如果运行在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上执行的代码
            text.setText("华为智慧屏");
            text.setTextColor(new Color(0xFFFF0000));
            text.setTextSize(200);
        } else if(DeviceInfo.getDeviceType().equals("wearable")) {
            // 运行在Wearable上执行的代码
            text.setText("华为智能手表");
            text.setTextColor(new Color(0xFF0000FF));
            text.setTextSize(50);
        }
        text.setTextAlignment(TextAlignment.CENTER);
        myLayout.addComponent(text);
        super.setUIContent(myLayout);
    }

在这段代码中,将TV和Wearable上显示的文本内容、文本尺寸和文本颜色做了改变,所以在TV和Wearable上显示的文本是不同的。在TV上显示的效果如图2所示。在Wearable上显示的效果如图3所示。

图2 在TV上显示的效果

图3 在Wearable上显示的效果
编辑:hfy

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

    关注

    36

    文章

    3293

    浏览量

    114201
  • 智慧屏
    +关注

    关注

    2

    文章

    356

    浏览量

    19702
  • HarmonyOS
    +关注

    关注

    79

    文章

    1977

    浏览量

    30264
收藏 人收藏

    评论

    相关推荐

    鸿蒙端实践-布局方案介绍

    封装到标签中实现,业务只需要针对标签简单地设置相关属性,即可实现列表类布局,大幅提升研发效率。同时动态化也支持绝对布局以及控制视图的显示和隐藏等功能,使之能胜任绝大多数业务布局场景。 在京东金融
    的头像 发表于 09-18 10:26 925次阅读
    <b class='flag-5'>鸿蒙</b><b class='flag-5'>跨</b>端实践-<b class='flag-5'>布局</b>方案介绍

    鸿蒙开发者预览版如何?

    在24年的华为鸿蒙发布会中表示。预览版已经向开发者开放申请,首批支持的机型有三款分别为华为 Mate 60、华为Mate 60 Pro、华为Mate X5。 其HarmonyOS NEXT去除
    发表于 02-17 21:54

    AKI语言调用库神助攻C/C++代码迁移至HarmonyOS NEXT

    /C++代码快速迁移至HarmonyOS NEXT。凭借卓越的兼容性,AKI已成为厂商与开发者打造鸿蒙原生应用过程中广泛使用的语言调用解决方案。 AKI是一款专为
    发表于 01-02 17:08

    如何理解鸿蒙OS是设备的?

    谁能帮忙解释鸿蒙OS是怎样实现平台的?
    发表于 09-08 18:17

    【HarmonyOS】开发设备鸿蒙(HarmonyOS) App

    设备单独开发App。例如,为手机开发一款App,为智能电视开发一款
    发表于 11-02 15:18

    【HarmonyOS】开发设备鸿蒙(HarmonyOS)App

    。例如,为手机开发一款App,为智能电视开发一款App,为智能手表开发一款App。这么做尽管从技
    发表于 11-03 16:54

    【HarmonyOS】鸿蒙小科普

    中间层,app设备端分别接入这些kit的sdk。 那么和直接用鸿蒙OS有什么区别呢? 开发会上官方给出了答案,不上鸿蒙也是可以实现的,不过
    发表于 11-04 09:36

    【HarmonyOS】鸿蒙小科普

    中间层,app设备端分别接入这些kit的sdk。 那么和直接用鸿蒙OS有什么区别呢? 开发会上官方给出了答案,不上鸿蒙也是可以实现的,不过
    发表于 11-04 11:03

    鸿蒙部分科普

    中间层,app设备端分别接入这些kit的sdk。 那么和直接用鸿蒙OS有什么区别呢? 开发会上官方给出了答案,不上鸿蒙也是可以实现的,不过
    发表于 11-04 13:53

    开发设备鸿蒙(HarmonyOS) App

    是可行的,但由于这些不同设备App,尽管在UI展现上不同,但大多数逻辑代码是相同的。如果单独为不同的设备开发
    发表于 11-13 09:38

    牛掰了!鸿蒙与Android完美融合,将鸿蒙设备当Android设备

    ,发现鸿蒙App开发方式与Android类似,更细心的小伙伴发现使用adb devices命令同样可以得到HarmonyOS模拟器列表,于是就不假思索地认为HarmonyOS是Android的套壳
    发表于 11-13 09:44

    鸿蒙应用开发入门资料合集

    通过XML的方式布局第一张页面,然后再通过代码的方式布局第二张页面。4、鸿蒙应用开发入门资料四:日志HiLog的使用做一个Java攻城师,
    发表于 03-22 11:23

    请问开发鸿蒙App的意义在哪里?

    这个问题也可以认为是鸿蒙原生App与Android App有什么区别,如果没有区别,本来Android开发好的应用,干嘛还要再去开发一遍
    发表于 04-13 11:10

    使用App Game Kit开发平台应用程序

    了解App Game Kit,一个易于使用的平台开发环境。 用户可以使用BASIC脚本编写代码,也可以使用带有C ++或XCode的库。
    的头像 发表于 11-06 07:38 4365次阅读

    鸿蒙APP开发鸿蒙权限请求框架

    关于 HarmonyOS 的动态授权的常规操作流程和代码我之前写过一篇文章:《鸿蒙动态权限申请完整规范流程和操作详解》。 文章地址如下: https://harmonyos.51cto.com
    的头像 发表于 09-28 09:19 2982次阅读