为了让更多的人看到本文,请各位读者动动小手,点击右上角【...】,将本文分享到朋友圈,thanks!

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

如果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")) {... ...
}

图1

其中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上显示的效果

- EOF -

推荐阅读  点击标题可跳转

1. 比Python更牛的语言有吗?看我用元类(metaclass)花式创建Python类

2. 见鬼!导入Python模块执行了所有代码,你不知道__name__变量是什么意思吗?

3. 连Python产生器(Generator)的原理都解释不了,还敢说Python用了5年?

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

5. 【鸿蒙学院】鸿蒙App开发直播学员提问与回答

6. 【鸿蒙学院】鸿蒙IDE:下载、安装DevEco Studio

7.  Python高效编程之88条军规(2):你真的会格式化字符串吗?

关注「极客起源」公众号,加星标,不错过精彩技术干货

开发跨设备的鸿蒙(HarmonyOS) App相关推荐

  1. 鸿蒙os事例代码,鸿蒙HarmonyOS App开发造轮子之自定义圆形图片组件的实例代码

    一.背景 在采用Java配合xml布局编写鸿蒙app页面的时候,发现sdk自带的Image组件并不能将图片设置成圆形,反复了翻阅了官方API手册(主要查阅了Compont和Image相关的API),起 ...

  2. 起航---开发基于国产华为鸿蒙操作系统的APP

    起航---开发基于国产华为鸿蒙操作系统的APP 从今儿个起,要准备学习开发三驾马车(苹果.安卓.华为)中的华为移动应用啦.很期待

  3. 开放源码,华为鸿蒙HarmonyOS 2.0来了

    作者 | Just 出品 | AI科技大本营(ID:rgznai100) 去年8月,鸿蒙HarmonyOS一经发布,在开发者群体中引发强烈反响.有人赞赏华为的战略和技术,但也有不少人质疑那只是个PPT ...

  4. 【鸿蒙 HarmonyOS】HarmonyOS 开发环境搭建 ( 下载 | 安装 | 启动 | 支持的设备与开发语言 )

    文章目录 一.HarmonyOS 开发环境下载 二.HarmonyOS 开发环境安装 三.启动 DevEco Studio 四.HarmonyOS 支持的设备与开发语言 一.HarmonyOS 开发环 ...

  5. 鸿蒙harmonyOS开发APP时,使用Retrofit+Java在get请求时遇到 ?pageNum=1pageSize=10的url 的get请求的写法

    鸿蒙harmonyOS开发APP时,使用Retrofit+Java在get请求时替换URL的时候会出现一个错误 java.lang.IllegalArgumentException: URL quer ...

  6. 鸿蒙应用开发在线体验官网,华为鸿蒙 HarmonyOS 应用开发在线体验网站上线

    原标题:华为鸿蒙 HarmonyOS 应用开发在线体验网站上线 IT之家 4 月 22 日消息 华为 HarmonyOS 应用开发在线体验网站现已上线. 开发者可以通过在线体验"To-Do ...

  7. 野火开发版屏幕_鸿蒙2.0手机开发者版发布,华为多数自研设备明年升级鸿蒙

    12月16日,华为在北京举办华为开发者日暨HarmonyOS 2.0手机开发者Beta版发布活动.开发者可访问华为开发者联盟官网,申请获取HarmonyOS 2.0手机开发者Beta版升级. &quo ...

  8. 鸿蒙应用开发培训笔记01:HarmonyOS介绍

    文章目录 零.本讲学习目标 一.鸿蒙系统理念与关键技术 (一)智能终端产业飞速发展带来历史性机遇 (二)HarmonyOS+超级终端,带给消费者的不一样 (三)HarmonyOS 开启万物互联时代的一 ...

  9. 鸿蒙os多设备如何实现,鸿蒙OS中如何实现跨设备迁移?

    01 分布式任务调度概述 在 HarmonyOS 中,分布式任务调度平台对搭载 HarmonyOS 的多设备构筑的"超级虚拟终端"提供统一的组件管理能力,为应用定义统一的能力基线. ...

最新文章

  1. Facebook 正在研究新型 AI 系统,以自我视角与世界进行交互
  2. python定义一个_Python,包括定义一个类
  3. Android Studio Gradle构建脚本
  4. qt中关于按钮的click()函数卓见
  5. jQuery的ajax提交表单
  6. linux脚本怎么发送到桌面,如何在Linux上使用Zenity创建简单的图形Shell脚本
  7. 用计算机教学体育,浅谈计算机在体育教学中的应用
  8. 用UltraISO制作CentOS的DVD光盘启动盘 安装系统
  9. 智慧交通之智能红绿灯调控系统分析
  10. python入门(三) 实现QQ自动发送消息
  11. Excel中无法查找和替换
  12. 中央处理器cpu中的什么是计算机的指挥中,计算机中央处理器CPU的组成有哪些
  13. 秀米如何在布局里面画图_毫无基础的人如何学习 CAD?
  14. 深入了解示波器(八):如何选择示波器
  15. 仿射密码加密解密(C语言)
  16. 万邦京东获取推荐商品列表 API
  17. 进入注册表的一些常用命令
  18. EVT/DVT/PVT/MP代表什么阶段
  19. 【面试题】N阶台阶,每次走一步或两步,计算共有多少种走法,并将每种走法打印出来。
  20. kubeadm方式搭建k8s集群

热门文章

  1. 传奇服务器的角色文件在,传奇版本等一些软件放到服务器里的方法
  2. js版【微信机器人】——wechat-robot
  3. 零基础学SQL(二、MYSQL数据类型)
  4. 微信小程序-实现元素渐入渐出动画效果-封装方法
  5. 简易的监控mysql_使用开源工具mysqlreport监控Mysql数据库-简易使用方法
  6. Keil_uvision 基本使用教程
  7. 微软官方建议的28条代码优化方案
  8. 数据可视化Matplotlib使用5-改变坐标轴的默认显示方式
  9. 我的家用户外监控摄像头的选购和安装记录
  10. CASS中基于高程点并生成等高线的方法