鸿蒙设备合作伙伴,开发跨设备的鸿蒙(HarmonyOS)App

eb6a25bfbd67f1dd7d0954320fd40a14.png

现在的智能设备种类越来越多,而且这些智能设备的屏幕尺寸、分辨率都不同,例如,比较常见的智能设备有手机、平板电脑、车载电脑、智能电视、智能手表等。尽管这些设备都有屏幕,但它们的屏幕千差万别,有的屏幕尺寸小,有的屏幕尺寸大,有的是纵向的屏幕,有的是横向的屏幕,有的带触摸功能,有的不带触摸功能,甚至有的设备的屏幕是圆形(如智能手表),这就给开发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")) {

... ...

}

0c836b41bf6a8e330d34e9a7e0e8c024.png

其中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所示。

5d7615cd9bc38098dd0a83637667ccf5.png 图2 在TV上显示的效果

07f7475b563da07a150a785facb6c4bb.png

图3 在Wearable上显示的效果

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 适合毕业设计、课程设计作业。这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。 所有源码均经过严格测试,可以直接运行,可以放心下载使用。有任何使用问题欢迎随时与博主沟通,第一时间进行解答!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值