首页 > 其他分享 >【纯血鸿蒙】——如何实现多端部署?(开发重点建议收藏)

【纯血鸿蒙】——如何实现多端部署?(开发重点建议收藏)

时间:2024-06-07 18:33:28浏览次数:37  
标签:多端 鸿蒙 适配 布局 能力 纯血 组件 模块 一多

一次开发,多端部署

介绍

鸿蒙系统采用微内核分布式系统的架构,分布式技术逐渐打破单一硬件边界,一个应用或服务,可以在不同的硬件设备之间随意调用、互助共享,让用户享受无缝的全场景体验。而作为应用开发者,广泛的设备类型也能为应用带来广大的潜在用户群体。但是如果一个应用需要在多个设备上提供同样的内容,则需要适配不同的屏幕尺寸和硬件,开发成本较高。HarmonyOS 系统面向多终端提供了一次开发,多端部署(简称为一多)的能力,让开发者可以基于一种设计,高效构建多端可运行的应用。

  • 这也是鸿蒙开发中的最重要的功能之一,可以实现一套代码工程,一次开发上架,多端按需部署。我在本文将会从界面级一多功能级一多工程级一多三个层面来实现。

img

  • 为了实现这个目标,主要解决 3 个核心问题:

img

  1. 页面适配问题:界面级一多(重点掌握)

  2. 功能兼容问题:功能级一多(了解)

  3. 工程如何组织:工程级一多(重点掌握)

img

1. 界面级一多(掌握)

界面级一多能力有两类:

  1. 自适应布局: 略微调整界面结构

  2. 响应式布局:比较大的界面调整

说明: 开发多设备上同一页面时,建议开发者多使用自定义组件,既可以增加代码的可读性和可维护性,同时也可以尽可能的实现代码复用。

布局可以分为自适应布局响应式布局,二者的介绍如下表所示。

名称简介
自适应布局当外部容器大小发生变化时,元素可以根据相对关系自动变化以适应外部容器变化的布局能力。相对关系如占比、固定宽高比、显示优先级等。当前自适应布局能力有7种:拉伸能力均分能力占比能力缩放能力延伸能力隐藏能力折行能力。自适应布局能力可以实现界面显示随外部容器大小连续变化。
响应式布局当外部容器大小发生变化时,元素可以根据断点、栅格或特定的特征(如屏幕方向、窗口宽高等)自动变化以适应外部容器变化的布局能力。当前响应式布局能力有3种:断点媒体查询栅格布局。响应式布局可以实现界面随外部容器大小有级不连续变化,通常不同特征下的界面显示会有较大的差异。

说明: 自适应布局多用于解决页面各区域内的布局差异,响应式布局多用于解决页面各区域间的布局差异。

自适应布局和响应式布局常常需要借助容器类组件实现,或与容器类组件搭配使用。

  • 自适应布局常常需要借助Row组件、Column组件或Flex组件实现。

  • 响应式布局常常与GridRow组件、Grid组件、List组件、Swiper组件或Tabs组件搭配使用。

接下来将依次介绍自适应布局和响应式布局,同时结合实际,通过典型布局场景以及典型页面场景详细介绍两种布局能力的用法。

2. 功能级一多开发(了解)

一个前提

功能开发的适配主要体现在需要适配不同范类的应用,比如既要适配手机和平板,也需要适配智能穿戴设备,如果是同泛类产品,系统能力一致,无需考虑多设备上应用功能开发的差异,我们的美寇商城需要适配的是手机和Pad,属于同泛类产品,无需考虑功能开发的差异。以下是常见类型分类:

  • 默认设备(一般为手机)、平板

  • 车机、智慧屏

  • 智能穿戴

什么是系统能力

系统能力(即SystemCapability,缩写为SysCap)指操作系统中每一个相对独立的特性,如蓝牙,WIFI,NFC,摄像头等,都是系统能力之一。每个系统能力对应多个API,随着目标设备是否支持该系统能力共同存在或消失。

如何适配系统能力

方法1:使用canUse接口判断设备是否支持某系统能力

if (canIUse("SystemCapability.Communication.NFC.Core")) {
   console.log("该设备支持SystemCapability.Communication.NFC.Core")
} else {
   console.log("该设备不支持SystemCapability.Communication.NFC.Core")
}

方法2:通过import动态导入,配合try/catch

import controller from '@ohos.nfc.controller'
try {
    controller.enableNfc()
    console.log("controller enableNfc success")
} catch (busiError) {
    console.log("controller enableNfc busiError: " + busiError)
}

注意:

  1. 目前的开发主要是 手机及平板开发,属于统一范类,功能差别不大

  2. 目前 Harmony Next 的系统首发登录的肯定是手机,其他设备会逐步接入

  3. 该部分内容目前了解即可

3. 工程级一多(掌握)

3.1. 工程管理

3.1.1 创建基本的空项目

参考工程管理,先创建出最基本的项目工程。可以看到DevEco Studio创建出的默认工程,仅包含一个的entry类型的模块。

  • 如果直接使用如下所示的平级目录进行模块管理,工程逻辑结构较混乱且模块间的依赖关系不够清晰,不利于开发及后期维护。(不推荐使用,跳过)

/application
├── common
├── feature1
├── feature2
├── featureN
├── wearable
├── default
└── productN

3.2. 工程创建

更推荐使用部署模型中介绍的common、features、product三层工程结构。工程结构示例如下所示:

/application
 ├── common                  # 公共特性目录
 │
 ├── features                # 功能模块目录
 │   ├── feature1            # 子功能
 │   ├── feature2            # 子功能2
 │   └── ...                 # 子功能n
 │
 └── product                 # 产品层目录
     ├── wearable            # 智能穿戴泛类目录
     ├── default             # 默认设备泛类目录
     └── ...
  • 接下来将依次介绍如何新建Module、修改配置文件以及调整目录,以实现“一多”推荐的“三层工程结构”。

一多模式下,官方推荐在开发过程中采用"三层工程架构",其实就是把项目拆分成不同类型的模块,再通过模块之间的引用组合,最终实现应用功能,拆分规范如下:

  • commons(公共能力层):用于存放公共基础能力合集,比如工具库,公共配置等

  • features(基础特性层):用于存放应用中相对独立的各个功能的UI以及业务逻辑实现

  • products(产品定制层):用于针对不同设备形态进行功能和特性集成,作为应用入口

3.2.1 模块包功能分类

参考官方的示例,将购物商城项目进行如下拆分:

img

  • 思路

  1. common设计为har包,新建module时选择Static Library, 内部存放全局通用的工具函数,公共配置等

  2. feature设计为har包,新建module时选择 Static Library, 内部存放相对独立的业务单元,比如购物车我的分类Home ,也就是首页底部Tab切换时的四个核心业务模块

  3. product为产品层,里面放置phone模块,也就是入口模块,在phone中我们放置入口ability和所有页面级别的组件

img

3.2.2 创建静态资源包

接下来咱们完成项目搭建,参考下图

img

核心步骤:

  1. 创建项目:项目名用 AGC 平台创建的项目名。

  2. 创建目录 commons、features、products。

  3. commons目录下:

    • 创建Static Library,起名 basic,存放全局通用的工具函数,公共配置等。

  1. features 目录下:

    • 创建Static Library:内部存放相对独立的业务单元,比如购物车我的分类Home ,也就是首页底部Tab切换时的四个核心业务模块。

  1. products 目录下:

    • 将原本的 entry,移入该目录并改名为 phone。

ok,项目结构已基本搭建完毕,后面文章会详细讲解具体多端设备适配的思路。

标签:多端,鸿蒙,适配,布局,能力,纯血,组件,模块,一多
From: https://blog.csdn.net/m0_68038853/article/details/139520826

相关文章

  • 鸿蒙HarmonyOS实战-ArkTS语言基础类库(通知)
    ......
  • 【最新鸿蒙应用开发】——沙箱机制是什么?作用?场景?
    沙箱机制1.什么是沙箱机制?1.1.概念在操作系统当中,沙箱机制(Sandboxing)是一种安全机制,用于限制程序代码的访问权限,防止恶意软件对系统造成破坏。在沙箱环境中,程序只能访问特定的资源,如文件、注册表、网络等,而不能访问其他系统资源。这样,即使恶意软件试图执行有害操作,也会因......
  • WebviewController进行混合开发,鸿蒙星河版API(11)
    @ohos.web.webview提供web控制能力,web组件提供网页显示的能力,同时也可以执行网页中定义的JS方法。一、第一步创建WebviewController实例controller:WebviewController=newwebview.WebviewController()二、web组件加载html文件build(){Navigation(){Col......
  • 鸿蒙HarmonyOS实战-ArkTS语言基础类库(容器类库)
    ......
  • 纯血鸿蒙和传统安卓的区别?优势?
    鸿蒙操作系统一、基于微内核架构的操作系统。什么是微内核设计?微内核设计是一种操作系统设计方法,它将操作系统的核心功能模块化,将尽可能多的功能移到用户空间,只在内核中保留最基本的功能,如进程管理和内存管理。微内核设计有助于提高系统的灵活性、可靠性和安全性,因为内核中的功......
  • 【鸿蒙】---鸿蒙Next小课堂之Promise
    前言Promise是一种用于处理异步操作的对象,可以将异步操作转换为类似于同步操作的风格,以方便代码编写和维护。简而言之:Promise用来管理异步,方便编码。这时候该有人要问了,怎么区分异步和同步呢?同步代码:逐行执行,需原地等待结果后,才继续向下执行。异步代码:调用后耗时,不阻塞......
  • 鸿蒙系统和MIUI之类的系统有何区别?
    文章目录2套鸿蒙系统MIUI或HyperOSHarmonyOS2套鸿蒙系统HarmonyOS(鸿蒙操作系统)是华为开发的一种面向全场景的分布式操作系统,设计初衷是为了实现不同设备间的无缝协同,提供一致的用户体验。它支持智能手机、智能穿戴、智慧屏、车机、智能家居等多种终端设备。Harmon......
  • 鸿蒙HarmonyOS实战-ArkTS语言基础类库(并发)
    ......
  • 鸿蒙真的为开发者带来了广阔的就业机会吗?
    前言鸿蒙(HarmonyOS)在2024年已经成为科技界的热点话题,被誉为“就业新蓝海”。那么,这股热潮是否真的为开发者带来了广阔的就业机会呢?鸿蒙系统的技术升级2024年的HarmonyOSNEXT版本,使鸿蒙系统成为一个独立且功能强大的操作系统,为用户带来更优质的体验,同时也为开发者们带来了......
  • 【HarmonyOS】鸿蒙系统中应用权限等级介绍、定义、申请授权讲解
    【HarmonyOS】鸿蒙系统中应用权限等级介绍、定义、申请授权讲解针对权限等级,相对于主体来说,会有不同的细分概念。一、权限APL等级:首先在鸿蒙系统中,对于权限本身,分为三个等级:normal,system_basic,system_core。普通应用为normal,可以访问相机,WIFI信息等资源特殊应用为sys......