HarmonyOS UI框架关键技术解析

发表于 3年以前  | 总阅读数:474 次

HarmonyOS UI框架提供了界面绘制相关的处理方法,例如:图形控件、页面布局和窗口管理(如图1所示)。 图1 UI框架

HarmonyOS UI框架采用的是ACE(Ability Cross-platform Environment)框架(如图2所示)。

ACE是一个应用开发框架,在OS架构之上,属于上层框架,目前支持JAVA和JS语言开发,两种语言框架具体区别如下:

1.JAVA UI框架提供了细粒度的UI编程接口,使应用开发更加灵活,元素以组件、布局的形式将界面绘制在窗口上。

2.JS UI框架采用类HTML和CSS声明式编程语言作为页面布局和页面样式的开发语言,页面业务逻辑则支持ECMAScript 规范的JavaScript语言。JS UI框架提供的声明式编程,可以让开发者避免编写UI状态切换的代码,视图配置信息更加直观。 图2 ACE UI框架

HarmonyOS UI框架关键技术

ACE JAVA UI框架

应用由Ability构成。Ability可以分为FA(Feature Ability)和PA(Particle Ability)两种类型。

❖Feature Ability(简称FA)支持Page Ability,一般用于用户交互,在屏幕上显示一个用户界面,该界面用来显示所有可被用户查看和交互的内容。用户界面由UI元素构成,通常包含布局、控件等形式,且元素支持设置资源和动画。

❖Particle Ability支持Data Ability(数据访问)和Service Ability(后台服务),一般用于后台业务逻辑的实现。 图3 JAVA UI

1 界面构成

每个用户界面的UI元素由组件树构成,即由Component和ComponentContainer对象构成(如图4所示)。

Java UI框架提供了一部分Component和ComponentContainer的具体子类,即创建用户界面(UI)的各类组件,包括一些常用的组件(比如:文本、按钮、图片、列表等)和常用的布局(比如:DirectionalLayout和DependentLayout)等。用户可通过组件进行交互操作,并获得响应。

Component:提供内容显示,是界面中所有组件的基类。

ComponentContainer:作为容器容纳Component或ComponentContainer对象,并对它们进行布局。

图4 JAVA UI组件树

2 Ability Page

Ability的构成

一个Page可以由一个或多个AbilitySlice构成,AbilitySlice是指应用的单个页面及其控制逻辑的总和。

图5 Page Ability构成

Ability的生命周期

下面是几个主要生命周期函数。

onStart()

当系统首次创建Page实例时,触发该回调。

● onActive()

Page会在进入INACTIVE状态后来到前台,然后系统调用此回调。Page在此之后进入ACTIVE状态,该状态是应用与用户交互的状态。

● onInactive()

当Page失去焦点时,系统将调用此回调,此后Page进入INACTIVE状态。

● onBackground()

如果Page不再对用户可见,系统将调用此回调,此后Page进入BACKGROUND状态。

● onForeground()

处于BACKGROUND状态的Page仍然驻留在内存中,当重新回到前台时,系统将先调用onForeground()回调通知开发者,而后Page的生命周期状态回到INACTIVE状态。

● onStop()

系统将要销毁Page时,将会触发此回调函数。

具体生命周期流程如下图所示:

图6 Java FA生命周期

Java Ability路由

Java FA提供三种路由方式:

1.Ability间的跳转(不同Ability)

2.Ability内部AbilitySlice间跳转

3.跨设备跳转 图7 Java FA路由

1.Ability间跳转(不同Ability):一个Ability跳转到另一个Ability时,根据不同的action选择不同的Slice。示例代码如下:

Intent intent = new Intent();
Operation operation = new Intent.OperationBuilder()
        .withAction("action2")
        .build();
intent.setOperation(operation);
startAbility(intent);

(左右滑动,查看更多)

如图7为示,Ability3通过addActionRoute接口配置了3条路由规则Router:

•action1路由到AbilitySlice1;

•action2路由到AbilitySlice2;

•action3路由到AbilitySlice3。

Ability1和Ability2分别通过startAbility跳转到Ability3,再根据三条路由规则选择各自对应的AbilitySlice。

其时序如图8所示: 图8 Ability间跳转

1.Ability2初始化时通过addActionRoute接口设置了路由规则。

2.Ability1通过startAbilityForResult跳转到Ability2时,Ability2根据action选择AbilitySlice1或AbilitySlice2。

3.当Ability2关闭返回时,Ability1通过onAbilityResult()回调方法,对请求结果进行处理。

2.Ability内部AbilitySlice间跳转

当发起导航的AbilitySlice和导航目标的AbilitySlice处于同一个Ability时,可以通过present()或presentForResult()方法实现导航。

同一个Page内的AbilitySlice导航,只需要指定目标AbilitySlice名称即可。AbilitySlice1通过present方法发起跳转,并指定目标名为AbilitySlice2,则跳转结果为显示AbilitySlice2。示例代码如下:

present(new AbilitySlice2(), new Intent());

(左右滑动,查看更多)

其时序如图9所示:

图9 AbilitySlice间跳转

1.Ability3包含AbilitySlice1、AbilitySlice2、AbilitySlice3三个AbilitySlice,初始化时通过setMainRoute方法设置了默认界面为AbilitySlice1。

2.AbilitySlice1可通过present()发起导航到AbilitySlice2,导航完成后界面显示AbilitySlice2。

3.若AbilitySlice1希望从导航目标AbilitySlice3返回时,能够获得其返回结果,则可使用presentForResult()实现导航。当AbilitySlice3返回时,系统将回调onResult()给AbilitySlice1来接收和处理返回结果,其中返回结果由AbilitySlice3在其生命周期内通过setResult()进行设置。

3.跨设备跳转

Ability也支持跨设备的路由,即目标Ability即可以是本地设备的Ability,亦可以是同一用户的不同设备,只需在startAbility进行路由时通过withDeviceId指定对端的设备id即可。

如图10所示:Ability1通过action选择到Ability2的路由,且通过withDeviceId指定了目标设备B,则最终结果为设备B上Ability2的对应界面被拉起显示。 图10 跨设备路由

3 资源管理

JAVA UI框架下的资源管理目录如下: 图12 JAVA UI下资源目录结构 示例代码如下:

Java文件中,引用string.json文件中类型为“String”、名称为“app_name”的资源:

ohos.global.resource.ResourceManager resManager = this.getResourceManager();
String result = resManager.getElement(ResourceTable.String_app_name).getString();

(左右滑动,查看更多)

XML文件中,引用string.json文件中类型为“String”、名称为“app_name”的资源:

<?xml version="1.0" encoding="utf-8"?>
<DirectionalLayout xmlns:ohos="http://schemas.huawei.com/res/ohos"
    ohos:width="match_parent"
    ohos:height="match_parent"
    ohos:orientation="vertical">
    <Text ohos:text="$string:app_name"/>
</DirectionalLayout>

(左右滑动,查看更多)

ACE JS UI框架

JS UI框架是一种跨设备的高性能UI开发框架,支持声明式编程和跨设备多态UI。它包括应用层(Application)、前端框架层(Framework)、引擎层(Engine)和平台适配层(Porting Layer)。 图13 JS UI框架

❖ Application

应用层表示开发者使用JS UI框架开发的FA应用。

❖ Framework

前端框架层主要完成前端页面解析,以及提供MVVM(Model-View-ViewModel)开发模式、页面路由机制和自定义组件等能力。

❖ Engine

引擎层主要提供动画解析、DOM(Document Object Model)树构建、布局计算、渲染命令构建与绘制、事件管理和平台channel机制等能力。

❖ Porting Layer

适配层主要完成对平台层进行抽象,提供具体抽象接口,可以对接到不同系统平台。比如:事件对接、渲染管线对接和系统生命周期对接等。

1 界面构成

每个用户界面的 UI布局由HML+CSS文件完成,响应及业务逻辑由JS文件完成。 图14 JS应用构成

● HML(HarmonyOS Markup Language)是一套类HTML的标记语言,通过组件,事件构建出页面的内容。页面具备数据绑定、事件绑定、列表渲染、条件渲染和逻辑控制等高级能力。

● CSS是描述HML页面结构的样式语言。

● JS文件用来定义HML页面的业务逻辑,支持ECMA规范的JavaScript语言。示例代码如下: 图15 JS UI代码示例

其中,UI布局由HML和CSS完成:

HML里

页签设置了界面组件,组件样式由container类定义,组件中包含文本控件text,文本内容由{{title}}填充,并给该文本控件设置了点击响应事件onclick,在控件被点击时执行change方法。

CSS里声明了样式,如container类设置了HML里

页签组件的方向和元素对齐方式。

对应的业务逻辑在JavaScript完成:

初始化时,将title设置为“hello world”,即刷新了文本控件text的填充内容{{title}}。

组件(Component)是构建页面的核心,每个组件通过对数据和方法的简单封装,实现独立的可视、可交互功能单元。 图16 组件分类

关于【组件详情】,请参考官网资料:

● 组件详情

https://developer.harmonyos.com/cn/docs/documentation/doc-guides/ui-js-building-ui-component-0000000000500580

2 Ability JS UI的Ability生命周期

下面是几个主要生命周期函数。

● onCreate ()

当应用创建时调用。(应用的生命周期)

● onInit ()

页面数据初始化完成时触发,只触发一次。

● onReady ()

页面创建完成时触发,只触发一次。

● onShow ()

页面显示时触发。

● onHide ()

页面消失时触发。

● onDestroy ()

页面销毁时触发。具体生命周期流程如下图所示:

图17 JS FA页面生命周期

JS Ability路由

JS FA也提供了三种路由方式:

1.Ability间的跳转

2.Ability内部JS page间跳转

3.跨设备跳转

图18 JS FA路由

1.Ability 间的跳转

JS中的Ability继承自AceAbility。

AceAbility间的跳转JS接口通过FeatureAbility.startAbility完成:

let actionData = {
      uri: 'www.huawei.com'
    };
    let target = {
      bundleName: "com.example.harmonydevsample",
      abilityName: "com.example.harmonydevsample.EntryJSApiAbility",
      data: actionData
    };

    let result = await FeatureAbility.startAbility(target);
    let ret = JSON.parse(result);
    if (ret.code == 0) {
      console.log('success');
    } else {
      console.log('cannot start browing service, reason: ' + ret.data);
    }

(左右滑动,查看更多)

2.Ability内部 JS page 间跳转

JS的Ability中可有多个不同页面,每个界面是一个Js Page(在pages目录下定义),如下面的ability包含了index和detail 2个页面:

{
  ...
  "pages": [
    "pages/index/index",
    "pages/detail/detail"
  ]
  ...
}

JS Page间可通过router跳转,例如跳转到detail的页面:

import router from '@system.router';
router.push({
     uri: "pages/detail/detail",
     params: {
          eventId: item,
     }
});

(左右滑动,查看更多)

3.跨设备跳转

跨设备跳转路由原理同Java UI上跨设备一样,只是JS UI中提供的是对应JS的接口:

FeatureAbility.startAbility(OBJECT)
FeatureAbility.startAbilityForResult(OBJECT)

(左右滑动,查看更多)

3 资源管理

JS UI框架下的资源管理目录如下:

图19 JS UI下资源目录结构

● app.js文件用于全局JavaScript逻辑和应用生命周期管理。

● pages目录用于存放所有组件页面。

● common目录用于存放公共资源文件,比如:媒体资源,自定义组件和JS文件。

● resources目录用于存放资源配置文件,比如:全局样式、多分辨率加载等配置文件。

● i18n目录用于配置不同语言场景资源内容,比如:应用文本词条,图片路径等资源。资源文件命名为“语言-地区.json”格式。其中,

● .hml结尾的HML模板文件,这个文件用来描述当前页面的文件布局结构。

● .css结尾的CSS样式文件,这个文件用于描述页面样式。

● .js结尾的JS文件,这个文件用于处理页面和用户的交互。

资源引用: ❖ $t方法引用资源,$t既可以在hml中使用,也可以在js中使用,$t参数说明如下: 示例代码如下:

• en-US.json中定义:

{
    "strings": {
        "hello": "Hello world!",
    ……
    },
}

• HML中引用:

<div>
  <!-- text中显示“Hello world!” -->
  <text>{{ $t('strings.hello') }}</text>
</div>

(左右滑动,查看更多)

• JS中引用:

export default {
  data: {
    hello: '',
  },
  onInit() {
    this.hello = this.$t('strings.hello');
  },   
}

(左右滑动,查看更多)

❖ 单复数通过$tc引用资源,定义单复数资源的内容通过json格式的key为“zero”、“one”、“two”、“few”、“many”和“other”区分,$tc参数说明如下: 示例代码例如下:

• en-US.json中定义:

{
    "strings": {
        "people": {
            "one": "one person",
            "other": "{count} people"
        }
    }
}

• HML中引用:

<div>
<!-- 传递数值为2时:"2 people" 阿拉伯语中此处匹配key为two的词条-->
  <text>{{ $tc('strings.people', 2) }}</text>
</div>

(左右滑动,查看更多)

• JS中引用:

export default {
  data: {
    people: '',
  },
  onInit() {
    this. people = this.$tc('strings.people', 2);
  },   
}

(左右滑动,查看更多)

❖ $r方法引用资源,$r既可以在hml中使用,也可以在js中使用,$r参数说明如下: 示例代码如下:

• res-ldpi.json中定义:

{
    "image": {
        "wearable": "common/wearable.png",
        ……
     }
}

• HML中引用:

<div>
  <!-- 通过$r来设置对应图片资源在json配置文件中的path -->
  <image src="{{ $r('image.wearable') }}" class="image"></image>
</div>

(左右滑动,查看更多)

• JS中引用:

export default {
  private: {
    wearable: '',
  },
  onInit() {
    // 资源格式化:
    this. wearable= this.$r('image. wearable');
  },    
}

(左右滑动,查看更多)

动手实例

我们为大家带来两个分别基于Java UI框架和Js UI 框架的Codelab作为HarmonyOS应用UI开发动手实例。

感兴趣的同学可以到HarmonyOS官网Codelabs栏目中参考其具体流程,动手实践一把。

● HarmonyOS JAVA通用组件

https://developer.huawei.com/consumer/cn/codelabsPortal/carddetails/HarmonyOS-JAVA-Components

● 基于JS通用组件的购物应用

https://developer.huawei.com/consumer/cn/codelabsPortal/carddetails/JS-COMPONENTS https://developer.huawei.com/consumer/cn/codelabsPortal/carddetails/JS-COMPONENTS

最后,本文描述的HarmonyOS应用UI开发方法可以覆盖大部分简单业务,开发者可以根据需求自由选择JS或者JAVA框架来完成。

本文由哈喽比特于3年以前收录,如有侵权请联系我们。
文章来源:https://mp.weixin.qq.com/s/DHUwYagdhsAj3j7ed3dcwg

 相关推荐

刘强东夫妇:“移民美国”传言被驳斥

京东创始人刘强东和其妻子章泽天最近成为了互联网舆论关注的焦点。有关他们“移民美国”和在美国购买豪宅的传言在互联网上广泛传播。然而,京东官方通过微博发言人发布的消息澄清了这些传言,称这些言论纯属虚假信息和蓄意捏造。

发布于:1年以前  |  808次阅读  |  详细内容 »

博主曝三大运营商,将集体采购百万台华为Mate60系列

日前,据博主“@超能数码君老周”爆料,国内三大运营商中国移动、中国电信和中国联通预计将集体采购百万台规模的华为Mate60系列手机。

发布于:1年以前  |  770次阅读  |  详细内容 »

ASML CEO警告:出口管制不是可行做法,不要“逼迫中国大陆创新”

据报道,荷兰半导体设备公司ASML正看到美国对华遏制政策的负面影响。阿斯麦(ASML)CEO彼得·温宁克在一档电视节目中分享了他对中国大陆问题以及该公司面临的出口管制和保护主义的看法。彼得曾在多个场合表达了他对出口管制以及中荷经济关系的担忧。

发布于:1年以前  |  756次阅读  |  详细内容 »

抖音中长视频App青桃更名抖音精选,字节再发力对抗B站

今年早些时候,抖音悄然上线了一款名为“青桃”的 App,Slogan 为“看见你的热爱”,根据应用介绍可知,“青桃”是一个属于年轻人的兴趣知识视频平台,由抖音官方出品的中长视频关联版本,整体风格有些类似B站。

发布于:1年以前  |  648次阅读  |  详细内容 »

威马CDO:中国每百户家庭仅17户有车

日前,威马汽车首席数据官梅松林转发了一份“世界各国地区拥车率排行榜”,同时,他发文表示:中国汽车普及率低于非洲国家尼日利亚,每百户家庭仅17户有车。意大利世界排名第一,每十户中九户有车。

发布于:1年以前  |  589次阅读  |  详细内容 »

研究发现维生素 C 等抗氧化剂会刺激癌症生长和转移

近日,一项新的研究发现,维生素 C 和 E 等抗氧化剂会激活一种机制,刺激癌症肿瘤中新血管的生长,帮助它们生长和扩散。

发布于:1年以前  |  449次阅读  |  详细内容 »

苹果据称正引入3D打印技术,用以生产智能手表的钢质底盘

据媒体援引消息人士报道,苹果公司正在测试使用3D打印技术来生产其智能手表的钢质底盘。消息传出后,3D系统一度大涨超10%,不过截至周三收盘,该股涨幅回落至2%以内。

发布于:1年以前  |  446次阅读  |  详细内容 »

千万级抖音网红秀才账号被封禁

9月2日,坐拥千万粉丝的网红主播“秀才”账号被封禁,在社交媒体平台上引发热议。平台相关负责人表示,“秀才”账号违反平台相关规定,已封禁。据知情人士透露,秀才近期被举报存在违法行为,这可能是他被封禁的部分原因。据悉,“秀才”年龄39岁,是安徽省亳州市蒙城县人,抖音网红,粉丝数量超1200万。他曾被称为“中老年...

发布于:1年以前  |  445次阅读  |  详细内容 »

亚马逊股东起诉公司和贝索斯,称其在购买卫星发射服务时忽视了 SpaceX

9月3日消息,亚马逊的一些股东,包括持有该公司股票的一家养老基金,日前对亚马逊、其创始人贝索斯和其董事会提起诉讼,指控他们在为 Project Kuiper 卫星星座项目购买发射服务时“违反了信义义务”。

发布于:1年以前  |  444次阅读  |  详细内容 »

苹果上线AppsbyApple网站,以推广自家应用程序

据消息,为推广自家应用,苹果现推出了一个名为“Apps by Apple”的网站,展示了苹果为旗下产品(如 iPhone、iPad、Apple Watch、Mac 和 Apple TV)开发的各种应用程序。

发布于:1年以前  |  442次阅读  |  详细内容 »

特斯拉美国降价引发投资者不满:“这是短期麻醉剂”

特斯拉本周在美国大幅下调Model S和X售价,引发了该公司一些最坚定支持者的不满。知名特斯拉多头、未来基金(Future Fund)管理合伙人加里·布莱克发帖称,降价是一种“短期麻醉剂”,会让潜在客户等待进一步降价。

发布于:1年以前  |  441次阅读  |  详细内容 »

光刻机巨头阿斯麦:拿到许可,继续对华出口

据外媒9月2日报道,荷兰半导体设备制造商阿斯麦称,尽管荷兰政府颁布的半导体设备出口管制新规9月正式生效,但该公司已获得在2023年底以前向中国运送受限制芯片制造机器的许可。

发布于:1年以前  |  437次阅读  |  详细内容 »

马斯克与库克首次隔空合作:为苹果提供卫星服务

近日,根据美国证券交易委员会的文件显示,苹果卫星服务提供商 Globalstar 近期向马斯克旗下的 SpaceX 支付 6400 万美元(约 4.65 亿元人民币)。用于在 2023-2025 年期间,发射卫星,进一步扩展苹果 iPhone 系列的 SOS 卫星服务。

发布于:1年以前  |  430次阅读  |  详细内容 »

𝕏(推特)调整隐私政策,可拿用户发布的信息训练 AI 模型

据报道,马斯克旗下社交平台𝕏(推特)日前调整了隐私政策,允许 𝕏 使用用户发布的信息来训练其人工智能(AI)模型。新的隐私政策将于 9 月 29 日生效。新政策规定,𝕏可能会使用所收集到的平台信息和公开可用的信息,来帮助训练 𝕏 的机器学习或人工智能模型。

发布于:1年以前  |  428次阅读  |  详细内容 »

荣耀CEO谈华为手机回归:替老同事们高兴,对行业也是好事

9月2日,荣耀CEO赵明在采访中谈及华为手机回归时表示,替老同事们高兴,觉得手机行业,由于华为的回归,让竞争充满了更多的可能性和更多的魅力,对行业来说也是件好事。

发布于:1年以前  |  423次阅读  |  详细内容 »

AI操控无人机能力超越人类冠军

《自然》30日发表的一篇论文报道了一个名为Swift的人工智能(AI)系统,该系统驾驶无人机的能力可在真实世界中一对一冠军赛里战胜人类对手。

发布于:1年以前  |  423次阅读  |  详细内容 »

AI生成的蘑菇科普书存在可致命错误

近日,非营利组织纽约真菌学会(NYMS)发出警告,表示亚马逊为代表的电商平台上,充斥着各种AI生成的蘑菇觅食科普书籍,其中存在诸多错误。

发布于:1年以前  |  420次阅读  |  详细内容 »

社交媒体平台𝕏计划收集用户生物识别数据与工作教育经历

社交媒体平台𝕏(原推特)新隐私政策提到:“在您同意的情况下,我们可能出于安全、安保和身份识别目的收集和使用您的生物识别信息。”

发布于:1年以前  |  411次阅读  |  详细内容 »

国产扫地机器人热销欧洲,国产割草机器人抢占欧洲草坪

2023年德国柏林消费电子展上,各大企业都带来了最新的理念和产品,而高端化、本土化的中国产品正在不断吸引欧洲等国际市场的目光。

发布于:1年以前  |  406次阅读  |  详细内容 »

罗永浩吐槽iPhone15和14不会有区别,除了序列号变了

罗永浩日前在直播中吐槽苹果即将推出的 iPhone 新品,具体内容为:“以我对我‘子公司’的了解,我认为 iPhone 15 跟 iPhone 14 不会有什么区别的,除了序(列)号变了,这个‘不要脸’的东西,这个‘臭厨子’。

发布于:1年以前  |  398次阅读  |  详细内容 »
 相关文章
Android插件化方案 5年以前  |  237298次阅读
vscode超好用的代码书签插件Bookmarks 2年以前  |  8139次阅读
 目录