HarmonyOS 5.0 Next实战应用开发—‘我的家乡’【HarmonyOS Next华为公司完全自研的操作系统】

简介: HarmonyOS NEXT是华为自研的鸿蒙操作系统的重要版本更新,标志着鸿蒙系统首次完全脱离Linux内核及安卓开放源代码项目(AOSP),仅支持鸿蒙内核和鸿蒙系统的应用。该版本引入了“和谐美学”设计理念,通过先进的物理渲染引擎还原真实世界的光影色彩,为用户带来沉浸式体验。应用图标设计融合国画理念,采用留白和实时模糊技术展现中式美学。HarmonyOS NEXT强化了设备间的协同能力,支持无缝切换任务,如在手机、平板或电脑间继续阅读文章或编辑文件。系统注重数据安全和隐私保护,提供数据加密和隐私权限管理功能。此外,它利用分布式技术实现跨设备资源共

HarmonyOS 5.0 Next

HarmonyOS NEXT是鸿蒙抛弃Linux内核及安卓开放源代码项目(AOSP)等代码的首个大版本,该系统仅支持鸿蒙内核和鸿蒙系统的应用,不再兼容安卓应用。
引入了“和谐美学”设计理念,通过先进的物理渲染引擎,细腻地还原了真实世界的光影色彩与时空力感,为用户呈现更加沉浸、多彩且灵动的感官体验。
应用图标设计巧妙融入了国画的理念,用恰到好处的留白取代繁复的内容展示,同时结合取色与实时模糊技术,展示着中式美学的平衡与和谐之感。
智慧美学构图功能强大,能够智能识别并裁剪出风景或人物的最佳比例,配合不同字体及位置,使得壁纸的整体效果更加和谐、美观。

HarmonyOS NEXT作为华为自研的操作系统,在技术创新、设计理念、创新功能以及生态发展等方面都取得了显著成果。它的发布不仅为用户带来了更加便捷、智能的体验,也为华为在智能设备协同领域的发展奠定了坚实基础。
在这里插入图片描述
HarmonyOS NEXT作为华为自研的操作系统,具有一系列独特的功能特点,这些特点旨在提升用户体验、增强设备间的协同性以及保障系统的安全性和稳定性。以下是对HarmonyOS NEXT功能特点的详细介绍:

原生鸿蒙应用支持:
HarmonyOS NEXT是首个完全基于鸿蒙内核和鸿蒙系统应用构建的版本,不再依赖Linux内核及安卓开放源代码项目(AOSP)等代码。
这意味着用户将能够体验到更加纯净、高效的鸿蒙系统,同时享受专为鸿蒙系统设计的原生应用。
设备协同与接续功能:
HarmonyOS NEXT强化了设备间的协同能力,使得用户可以在不同设备间无缝切换任务。
例如,用户可以在手机上开始阅读一篇文章,然后在平板或电脑上继续阅读,而无需重新加载或查找内容。
这种接续功能支持多种场景,如阅读、创作、修图、看视频等,并适配了众多第三方应用。
智慧美学设计:
HarmonyOS NEXT引入了“和谐美学”设计理念,通过先进的物理渲染引擎和细腻的光影色彩与时空力感呈现,为用户带来更加沉浸、多彩且灵动的感官体验。
应用图标设计巧妙融入了国画理念,用留白取代繁复的内容展示,同时结合取色与实时模糊技术,展现中式美学的平衡与和谐。
安全与隐私保护:
HarmonyOS NEXT注重用户的数据安全和隐私保护,采用了多项安全措施来确保用户信息的安全。
例如,系统提供了数据加密、隐私权限管理等功能,让用户能够更加放心地使用设备。
分布式技术:
HarmonyOS NEXT利用了分布式技术,使得不同设备可以组成一个超级终端,实现资源共享和协同工作。
这种技术为用户带来了更加便捷、高效的使用体验,如跨设备文件传输、跨设备通话等。
开发者支持:
HarmonyOS NEXT为开发者提供了丰富的开发工具和资源,帮助他们更轻松地创建和优化鸿蒙应用。
这些工具和资源包括开发工具包(SDK)、模拟器、文档等,有助于降低开发门槛并提高开发效率。
持续更新与升级:
HarmonyOS NEXT将持续进行更新和升级,以修复已知问题、引入新功能并提升系统性能。
在这里插入图片描述

华为将定期发布更新包,确保用户能够始终享受到最新、最稳定的系统版本。
综上所述,HarmonyOS NEXT具有原生鸿蒙应用支持、设备协同与接续功能、智慧美学设计、安全与隐私保护、分布式技术、开发者支持以及持续更新与升级等独特的功能特点。这些特点使得HarmonyOS NEXT在用户体验、设备协同以及系统安全性等方面都取得了显著的提升。

一.HarmonyOS Next—华为公司完全自研的操作系统

2024年1月18日鸿蒙生态千帆启航仪式在深圳举办,正式揭开纯血鸿蒙的新篇章。“轻舟已过万重山”鸿蒙操作系统以令世界惊艳的速度成长,成为iOS和安卓的有力竞争者,推翻了他们的双头垄断地位。仅仅四年的时间,使用鸿蒙系统的设备已经超过7亿,而参与鸿蒙开发的开发者数量也超过了220万。

经过多年的努力,华为鸿蒙系统加速了生态系统的构建,其发展计划也十分明确:兼容→搬迁→脱离安卓。目前,华为鸿蒙生态接入设备数量已超过7亿台。在基于华为鸿蒙系统的使用过程中,用户和开发者都已经形成了新的习惯,因此在2024年第一季度,鸿蒙系统的NEXT星河版本将不再兼容Android。

在这里插入图片描述

1.1什么是HarmonyOS Next?

HarmonyOS NEXT是华为公司自研的操作系统,它是鸿蒙抛弃Linux内核及安卓开放源代码项目(AOSP)等代码的首个大版本,该系统仅支持鸿蒙内核和鸿蒙系统的应用,不再兼容安卓应用,因此被称为“纯血鸿蒙”。

HarmonyOS NEXT采用了轻量化的设计理念,针对不同设备进行定制化开发,使得系统运行更加流畅、高效。同时,该系统还提供了丰富的开发工具和组件,让开发者能够更加便捷地构建应用,降低了开发门槛。

在安全性方面,HarmonyOS NEXT采用了更加严格的数据加密和隐私保护措施,确保用户数据的安全可靠。同时,它还支持可信执行环境,为开发者提供了更加安全的应用运行环境。

在这里插入图片描述

此外,华为积极构建HarmonyOS NEXT生态圈,与众多厂商和开发者合作,共同打造一个开放、共享、繁荣的应用生态。在2024年,华为计划协助企业和机构在年底开发逾5000个鸿蒙原生应用,最终实现超50万个原生应用的开发。

在最新的发展动态中,高德开放平台已经发布了HarmonyOS NEXT定位、地图SDK,助力鸿蒙生态发展。这表明,基于HarmonyOS NEXT开发的鸿蒙原生应用能力正在逐步增强,鸿蒙生态也在持续壮大。

HarmonyOS NEXT作为华为自研的操作系统,不仅具有高效、安全、轻量化等特点,还在不断推动鸿蒙生态的发展和完善,为未来的智能设备和应用开发提供了更多的可能性。

1.2HarmonyOS Next三大核心技术理念

1.一次开发,多端部署。

一次开发,多端部署指的是一个工程,一次开发上架,多端按需部署。目的是支撑开发者高效地开发多种终端设备上的应用。为了实现这一目的,鸿蒙系统提供了几个核心能力,包括多端开发环境,多端开发能力以及多端分发机制。一次开发,多端部署是HarmonyOS Next的一项重要特性和核心理念。

开发者们只需要使用一套API进行开发,就能够同时适应手机、平板、智能电视等各种类型的设备。这样大大降低了开发的复杂性和成本,提升了开发效率。

在这里插入图片描述

2.可分可合,自由流转。

HarmonyOS Next采用了分布式体系架构,能够实现多设备间的资源共享和协同。这使得在多设备环境下的应用体验能够自由地在各个设备间流转,保证了用户体验的连贯性和丰富性。

可分可合是指鸿蒙生态中的应用和服务可以根据需要进行拆分和组合。在开发过程中,开发者通过业务解耦,将不同的业务拆分为多个模块。
在应用部署阶段,开发者可以自由组合一个或多个模块,打包成一个应用程序包(App Pack),以便统一上架。

在分发和运行阶段,每个模块可以独立分发,以满足用户单一的使用场景,也可以组合多模块以满足用户更复杂的使用场景。

在这里插入图片描述

自由流转是指这些拆分和组合后的应用和服务可以在鸿蒙生态中自由流转。鸿蒙系统通过统一的账户体系和设备认证机制,实现了不同设备之间的无缝连接和协同工作。这意味着用户可以在不同设备之间自由切换,而无需担心数据和服务的同步问题。

同时,鸿蒙系统还支持跨设备任务接续和资源共享,用户可以在不同设备上无缝继续之前的工作或娱乐体验。自由流转可分为跨端迁移和多端协同两种情况。他们分别是时间上的串行交互和时间上的并行交互。自由流转不仅带给用户全新的交互体验,也为开发者搭建了一座从单设备时代通往多设备时代的桥梁。

3.统一生态,原生智能。

统一生态,原生智能意味着HarmonyOS Next在不同设备间构建了统一的操作逻辑和用法,用户在各个设备间切换时得到的都是一致的用户体验。

同时,分布式系统的设计使得智能能够广泛地应用于系统中,提升了系统对用户需求的洞察力和满足力。通过统一生态,鸿蒙成功构建了一个开放、共生、共荣的开发者环境,使得开发者能够在这个平台上共享资源、技术和经验,同时HarmonyOS与OpenHarmony统一生态,共同推动鸿蒙生态的繁荣发展。

鸿蒙系统内置强大的 AI 能力,面向鸿蒙生态应用的开发,通过不同层次的AI能力开放, 满足开发者的不同开发场景下的诉求,降低应用的开发门槛,帮助开发者快速实现应用智能化。

二.HarmonyOS Next 两种应用形态

HarmonyOS应用(也被称为鸿蒙OS应用) 是指利用HarmonyOS SDK开发的应用程序,在华为终端设备(例如手机、平板等)上运行,这些应用有两种形态。

  • 传统方式的应用,需要用户进行安装的应用包。

  • 元服务,是一种轻量级的应用形式,无需安装即可使用,随时随地提供服务,具有直接接入服务、灵活自由流通等关键特点。

2.1什么是HarmonyOS Next元服务?

鸿蒙元服务是华为鸿蒙操作系统中提供的一系列核心服务。它是基于HarmonyOS API的全新服务提供方式,具有即用即走、信息外显、服务直达的特性。

鸿蒙元服务仅需开发一次,即可支持多终端设备运行,并以鸿蒙万能卡片等多种呈现形态,向用户提供更轻量化的服务。鸿蒙万能卡片是元服务最主要的呈现形态之一,每一个万能卡片都是在桌面上“永远打开的”元服务/应用,将元服务/应用的重要信息以卡片的形式展示在桌面,通过轻量交互行为实现服务直达。

在这里插入图片描述

鸿蒙元服务还涵盖了设备接入、资源调度、分布式能力等多个方面。它提供了强大的设备接入能力,支持各类智能设备快速接入操作系统,并能够充分利用设备的硬件资源。这意味着用户可以通过鸿蒙系统将多个设备连接到一起,实现灵活的设备互联,享受更加便捷、高效和安全的智能互联体验。

鸿蒙元服务是鸿蒙操作系统的重要组成部分,通过提供核心服务和优化设备间的互联互通,为用户带来了更出色的智能设备使用体验。

2.2元服务的呈现形态和优点

鸿蒙万能卡片是元服务最主要的呈现形态之一(其他形态如语音、图标等),每一个万能卡片都是在桌面上“永远打开的”元服务/应用,将元服务/应用的重要信息以卡片的形式展示在桌面,通过轻量交互行为实现服务直达。

(1)免安装,更轻量化地将服务带给用户
(2)一键服务直达,将用户感兴趣的内容前置、外显
(3)跨端转移,多终端设备间无缝流转
(4)情景智能卡片推荐,随心定制、更懂用户

在这里插入图片描述

三.Harmony Next 实战—“我的家乡”元服务

在广袤无垠的草原上,奔腾的骏马是自由的象征,也是家乡独特的风景线。在这个充满活力和魅力的地方,我基于华为鸿蒙操作系统HarmonyOS Next,倾力打造了一款名为我的家乡”的元服务。

3.1视频演示

账号迁移中,视频暂时下架。

3.2项目构建

这些服务以新型应用程序形态呈现,相比传统需要安装的应用形态,更加轻量,同时提供更丰富的入口和更精准的分发。

在创建项目的模板选择页面选择Atomic Service和Empty Ability(空模板),创建元服务工程

在这里插入图片描述

创建成功后,DevEco Stdio就会创建整个应用,并且自动生成工程代码。

IDE界面说明如下。

  • 目录工程区主要用于管理和组织相关的工程文件、数据和其他资源。
  • 代码编辑区提供了一个可视化的界面,让开发者能够直接输入和编辑代码。具有语法高亮功能,能够自动识别和显示代码中不同元素(如变量、函数、关键字等)的颜色,从而提高代码的可读性。集成了错误检查工具,能够在开发者输入代码时实时检查语法错误和潜在问题。此外,通过连接调试器,开发者可以在编辑区内设置断点、查看变量值、执行单步调试等操作,帮助定位和解决问题。
  • 预览区是一个专门用于展示应用界面设计效果的区域,开发者可以在此查看和调试UI组件的布局、样式以及交互效果,从而确保应用界面的正确性和美观性。支持布局调试功能,开发者可以通过调整组件的位置、大小、边距等属性,实时查看布局变化。这有助于快速发现并修复布局问题,提高界面的可用性和美观性。
  • 通知栏是一个多功能区域,为开发者提供了丰富的工具和操作选项,有助于提高开发效率和代码质量。实时显示代码的错误、警告和提示信息,帮助开发者及时发现和修复问题。同时,它还显示项目的构建状态、调试状态等信息,让开发者了解项目的当前情况等等。

在这里插入图片描述

3.3登录页面构建

登录页面(Login Page)是一个用于用户进行身份验证的界面。在网站、应用程序或系统中,登录页面是用户输入其用户名和密码,以验证其身份并访问受保护的资源的地方。

在这里插入图片描述

对于本案例来说,登录页面主要是UI的设计。

核心代码如下:

  Column(){
      Image($r("app.media.logo")).width(400).margin({
        bottom:60
      })

      Column(){
        Text("用户名").fontWeight(FontWeight.Bold).margin({
          bottom:14
        })
        Row(){
          Image($r("app.media.user")).width(30)
          TextInput({
            placeholder:"请输入用户名",
            text:this.username
          }).width("70%")
            .onChange((value:string) => {
              this.username = value
            })
            .margin({
              bottom:14,
              left:14
            })
        }
        Divider().width("80%").margin({
          bottom:14
        })
        Text("密码").fontWeight(FontWeight.Bold).margin({
          top:10,
          bottom:14
        })
        Row(){
          Image($r("app.media.password")).width(30)
          TextInput({
            placeholder:"请输入密码",
            text:this.password,
          }).width("70%")
            .onChange((value:string) => {
              this.password = value
            })
            .margin({
              bottom:14,
              left:14
            })
            .type(InputType.Password)

        }
        Divider().width("80%").margin({
          bottom:14
        })
      }.alignItems(HorizontalAlign.Start)
      Row(){
        Blank()  
        Text("忘记密码?").fontColor('#ffcac7c7')
      }.width("60%").margin({
        left:50,
        top:20
      }).onClick(()=>{
        router.pushUrl({
          url:"pages/tabs"
        })
      })
      Button("登录").width(150).backgroundColor('#1086f0')
        .margin({
          top:30,
          bottom:30
        }).onClick(() => {
        router.pushUrl({
          url:"pages/tabs",
          params:{ 
            name:this.username
          }
        })
      })

      Text("立即注册").margin({
        top:20
      }).fontColor('black')
        .onClick(()=>{
          router.pushUrl({
            url:"pages/RegisterPage"
          })
        }).fontWeight(FontWeight.Bold)

    }.backgroundImage('/picture/background.jpg',ImageRepeat.NoRepeat)
    .backgroundImageSize(ImageSize.Cover)
    .border({ width: 1 })
    .width("100%").height("100%").alignItems(HorizontalAlign.Center).justifyContent(FlexAlign.Center)

3.4自定义底部导航页签

自定义底部导航页签在移动应用中起着关键作用。它们不仅提供了导航和定位的功能,使用户可以轻松浏览应用的各个部分,而且位于手机屏幕底部,便于用户操作。这种设计不仅增强了用户体验,还提高了应用的可用性和可发现性。通过保持一致的用户界面,底部导航页签还有助于用户更快地适应不同应用程序,并且在美学和设计方面也能提升应用的整体品质。

在这里插入图片描述

import { homepage } from './homepage'
import router from '@ohos.router';
import { CommuityPage } from './dynamic'
import { Personal } from './Personal'
@Entry
@Component
struct Index {
  @State currentIndex: number = 0
  private controller: TabsController = new TabsController()
  @State filterText: string = ''; // 添加一个状态用于保存搜索框的值
  // 自定义导航页签的样式
  @Builder TabBuilder(title: string, targetIndex: number, selectedImg: Resource, normalImg: Resource) {
    Column() {
      Image(this.currentIndex === targetIndex ? selectedImg : normalImg)
        .size({ width: 25, height: 25 })
      Text(title)
        .fontColor(this.currentIndex === targetIndex ? '#28bff1' : '#8a8a8a')
    }
    .width('100%')
    .height(50)
    .justifyContent(FlexAlign.Center)
    .onClick(() => {
      this.currentIndex = targetIndex
      this.controller.changeIndex(this.currentIndex)
    })
  }

  build() {
    Column() {
      Tabs({
        barPosition: BarPosition.End,
        controller: this.controller
      }) {
        TabContent() {
          homepage()
        }.tabBar(this.TabBuilder('首页', 0, $r('app.media.indexinco'), $r('app.media.indexinco')))

        TabContent() {
          Column() {
            CommuityPage()
          }.size({ width: '100%', height: '100%' })
        }.tabBar(this.TabBuilder('内蒙古动态', 1, $r('app.media.dongtai2'), $r('app.media.dongtai2')))

        TabContent() {
          Column() {
            Personal()
          }.size({ width: '100%', height: '100%' })
        }.tabBar(this.TabBuilder('我的', 2, $r('app.media.user1'), $r('app.media.user1')))
      }.scrollable(false) // 禁止滑动切换
    }
    .width('100%')
    .height('100%')
  }
}

页面组件,以@Entry和@Component注解标识,命名为Index。它导入了相关组件和库,并定义了一系列状态变量,如currentIndex和filterText,用于管理页面状态。通过Tabs组件实现了标签页功能,每个标签页对应不同的子页面(如homepage、CommuityPage和Personal),并提供了自定义导航页签样式的功能。

3.5首页页面构建

首页页面是任何网站或应用程序的门户,承载着多重重要功能。首先,它是用户与网站或应用程序首次接触的地方,因此扮演着传达品牌形象、引导用户的角色。其次,首页提供了对整体内容的概览,使用户可以快速了解核心特点和价值。

同时,通过明确的导航和吸引人的设计,首页还能促进用户转化和完成有意义的行为。此外,首页也是展示品牌定位和风格的平台,有助于增强用户对品牌的认知。最后,通过优化首页内容和结构,还能提高页面流量和搜索引擎优化效果。因此,首页页面在网站或应用程序中扮演着不可或缺的关键角色。

在这里插入图片描述

页面内导航代码如下:

Tabs({ barPosition: BarPosition.Start, controller: this.controller }) {
    // 页面1
    TabContent() {
        // 页面内容,包括图片、文字等
    }.tabBar(this.TabBuilder(0, '自然景观'))

    // 页面2
    TabContent() {
        // 页面内容,包括图片、文字等
    }.tabBar(this.TabBuilder(1, '民族文化'))

    // 页面3
    TabContent() {
        // 页面内容,包括图片、文字等
    }.tabBar(this.TabBuilder(2, '特色美食'))
}

我创建了一个 Tabs(标签页)组件,其中包含三个标签页(页面1、页面2、页面3)。每个标签页的内容由 TabContent() 函数定义,而标签栏(tabBar)则由 TabBuilder 函数定义。 TabBuilder 是一个自定义的函数,根据给定的索引和名称构建了一个标签。

自定义类TabBuilder代码如下:

  @Builder TabBuilder(index: number, name: string) {
    Column() {
      Text(name)
        .fontColor(this.currentIndex === index ? this.selectedFontColor : this.fontColor)
        .fontSize(16)
        .fontWeight(this.currentIndex === index ? 500 : 400)
        .lineHeight(22)
        .margin({ top: 0, bottom: 0 })

    }.width('100%')
  }

以上代码展示了一个首页页面的示例,主要包括了轮播图、搜索框和选项卡等元素,以及与之相关的交互逻辑。在该页面中,用户可以浏览不同类别的内容,如自然景观、民族文化和特色美食,并通过选项卡进行切换。每个选项卡下面都列有相应类别的内容,用户点击后可跳转至详细页面。
总体而言,该首页页面具有以下特点和功能:

  • 良好的布局设计:使用了适当的排列和布局,使页面内容清晰易读。
  • 交互性强:添加了点击事件处理函数,实现了用户点击后的页面跳转功能。
  • 多样化的内容展示:展示了不同类别的内容,满足了用户多样化的浏览需求。
  • 搜索功能:提供了搜索框,使用户可以根据关键字搜索感兴趣的内容。
  • 使用了Tabs组件进行页面内容切换,增强了用户体验。

该首页页面设计合理,功能丰富,能够有效地引导用户浏览和交互,提升了应用的用户体验。

3.6仿小某书动态页面构建

仿小某书动态页面是一种社交化的内容展示平台,其主要作用在于促进用户之间的互动和内容分享。通过用户可以发布、浏览和评论朋友们的动态内容,提供了一个交流的空间。这种社交互动不仅增强了用户之间的联系,也增加了用户对平台的粘性和活跃度。同时,动态页面也为用户提供了一个分享自己生活、观点和兴趣的平台,从而推广了各种形式的内容,包括文字、图片等。

在这里插入图片描述

自定义组件核心代码如下:

自定义组件核心代码如下:
build() {
    Row(){
      Column() {
        Image(this.img).width(170).height(150)
          .sharedTransition('sharedImage1', { duration: 1000, curve: Curve.Linear })
          .onClick(() => {
            router.pushUrl({ url: 'pages/sharedTransitionDst',params:{
              text:this.text,
              img:this.img
            } });
          })
        Text(this.textx).width(170)
          Row(){
            Image($r("app.media.pyqtoxiang")).width(30).height(30)
            Text(this.text).width(170).fontSize(15)
          }.width(170)
      }.margin({
        bottom:20
      })

      Column() {
        Image(this.img1).width(170).height(150) 
          .sharedTransition('img1', { duration: 1000, curve: Curve.Linear })
          .onClick(() => {
            router.pushUrl({ url: 'pages/sharedTransitionDst',params:{
              text1:this.text1,
              img1:this.img1
            } });
          })
        Text(this.text1x).width(170)
        Row(){
          Image($r("app.media.pyqtoxiang")).width(30).height(30)
          Text(this.text1).width(170).fontSize(15)
        }.width(180)

      }.margin({
        bottom:20,
        left:10
      })
    }

  }

核心代码是build()函数,其中定义了一个自定义组件Mycomponent,该组件包含两个列(Column),每个列内部包含一个图像(Image)、一个文本(Text)和一个行(Row),用于展示图像和相关文本信息。在图像上设置了点击事件,点击后通过路由跳转至下一页面。

仿小某书动态页面的作用是建立社交互动平台,促进用户之间的交流和内容分享。

3.7个人中心页面构建

个人中心页面是用户在应用程序或网站中管理个人信息和设置偏好的重要界面。其主要作用在于提供一个集中管理用户设置和偏好选项的入口,以便用户能够轻松地管理和维护自己的账户。

通过个人中心页面,用户可以满足个性化的需求和提升用户体验。此外,帮助用户更好地了解自己在平台上的活动情况。

在这里插入图片描述

核心代码如下:

build() {
    Column(){

      Image($r('app.media.toxiang'))
        .width("150vp")
        .margin({top:20})

      Item({
        text:"我是谁",
        img:$r("app.media.whois"),
      }).onClick(() => {
        promptAction.showDialog({
          message:"",
          buttons:[
            {
              text:"我已了解",
              color:$r("app.color.start_window_background")
            },
          ]
        }).then(data => {

          })
      })

      // 其他Item的类似代码...
    }.backgroundImage('/picture/pinkback.jpg',ImageRepeat.NoRepeat)
    .backgroundImageSize(ImageSize.Cover)
    .width('100%').height('100%')
  }
}

核心代码是build()函数,其中定义了一个名为Personal的组件。该组件内部包含了多个Item组件,每个Item代表一个功能选项,包括显示文字和对应图标,并设置了点击事件。点击不同的功能选项会触发不同的交互操作,例如显示对话框、跳转页面等。整体布局采用了Column包裹Item组件,以展示垂直排列的功能选项列表,并设置了背景图片和尺寸。

个人中心页面在增强用户管理能力、提升用户满意度等方面具有重要作用。

3.7服务卡片页面构建

鸿蒙的服务卡片是鸿蒙的一种界面展示形式,它将FA的重要信息或操作前置到卡片,以达到服务直达、减少体验层级的目的。

服务卡片通常用于嵌入到其他应用(当前卡片使用方只支持系统应用,如桌面)中作为其界面显示的一部分,并支持拉起页面、发送消息等基础的交互功能。它们能够展示更多信息,如天气预报、日程提醒等,使用户无需打开应用即可获取所需信息。通过与卡片进行交互,用户无需打开应用,就可以实现应用内的部分操作,使用十分便捷。

在这里插入图片描述

核心代码如下:

build() {
    Stack() {
      Image($r("app.media.back"))
        .objectFit(ImageFit.Cover)
      Column() {
        Text(`${this.currentQuestionIndex+1}`+'.'+`${this.title[this.currentQuestionIndex]}`)
          .fontSize(18)
        Row() {
          Text(`${this.where[this.currentQuestionIndex]}`)
            .fontSize(15)
            .margin(3)
        }
        Text(`${this.time[this.currentQuestionIndex]}`)
          .fontSize(12)
          .margin({top:5})
        Image('images/'+`${this.img[this.currentQuestionIndex]}`+".png")
          .width("100%")
          .height("50%")
          .onClick(() => {
          })
          .margin({top:10})

        if(this.ende){
          Button('到尽头了')
            .margin(1)
            .fontSize(10)
            .fontColor(Color.White)
            .backgroundColor("#499c54")
            .padding({ left: '2vp', right: '2vp' })
            .width("100%")
            .height("10%")
            .margin({ top: '4vp' })
        }else {
          if (this.flag[this.currentQuestionIndex]=='1'){
            Button('下一个')
              .margin(1)
              .fontSize(10)
              .fontColor(Color.White)
              .backgroundColor("#499c54")
              .padding({ left: '2vp', right: '2vp' })
              .width("100%")
              .height("10%")
              .margin({ top: '4vp' })
              .onClick(() => {
                this.onNextQuestion();
              });
          }
          else {
            Button('下一个')
              .margin(1)
              .fontSize(10)
              .fontColor(Color.White)
              .backgroundColor("#499c54")
              .padding({ left: '2vp', right: '2vp' })
              .width("100%")
              .height("10%")
              .margin({ top: '4vp' })
              .onClick(() => {
                this.onNextQuestion();
              });
          }
        }
      }
      .alignItems(HorizontalAlign.Start)
      .padding($r('app.float.column_padding'))
    }
  }
}

四.总结

HarmonyOS NEXT是华为公司自研的操作系统,它是鸿蒙抛弃Linux内核及安卓开放源代码项目(AOSP)等代码的首个大版本,该系统仅支持鸿蒙内核和鸿蒙系统的应用。

本文介绍了基于HarmonyOS Next操作系统开发的“我的家乡”元服务应用案例。首先,介绍了HarmonyOS Next作为华为公司完全自研的操作系统的特点和核心技术理念。随后,讨论了HarmonyOS Next两种应用形态,重点介绍了元服务的概念、呈现形态和优点。接着,通过实战演示了如何构建“马背上的家乡”元服务应用,包括项目构建、登录页面、自定义底部导航页签、首页页面、仿小某书动态页面、个人中心页面和服务卡片页面的构建过程。最后,提供了效果截图,并对整个应用开发过程进行了总结。
通过本文,读者可以深入了解HarmonyOS Next操作系统的特点和优势,了解元服务在应用开发中的应用形态和实际操作方法。同时,通过“马背上的家乡”元服务应用案例的实战演示,读者可以掌握如何利用HarmonyOS Next进行应用开发的具体步骤和技术要点。

在这里插入图片描述

HarmonyOS NEXT,即华为自研的鸿蒙操作系统的一个大版本更新,具有以下几个显著特点:

1.分布式架构:HarmonyOS NEXT采用了分布式架构设计,使多个设备之间能够实现资源共享和协同工作。用户通过一个设备即可操作其他设备的功能,从而提供更为流畅的用户体验。通过分布式软总线技术,不同设备可以像连接在一起一样方便地进行数据传输和交互,极大地提高了设备间的协同效率和用户体验。

2.高性能:HarmonyOS NEXT通过分布式调度算法,为不同设备提供最佳的计算资源分配,从而提高了设备的性能,提供了更快的响应速度。

3.安全可靠:HarmonyOS NEXT采用了多层次的安全策略,确保用户数据的隐私和安全。系统采用了更加严格的数据加密和隐私保护措施,并支持可信执行环境,为开发者提供了更加安全的应用运行环境。此外,它还可以对多种设备进行安全管理,包括智能手机、电视、智能家居设备等。

4.轻量化设计:HarmonyOS NEXT采用了轻量化的设计理念,针对不同设备进行定制化开发,使系统运行更加流畅、高效。同时,系统减少了40%的冗余代码,提升了系统的流畅度、能效以及安全性。

5.生态丰富:HarmonyOS NEXT致力于构建一个开放、共享、繁荣的应用生态。华为积极与众多厂商和开发者合作,共同推动鸿蒙生态的发展。目前,鸿蒙原生应用版图已经成型,涵盖了导航、新闻、工具、旅游、金融、便捷生活、美食、游戏等多个领域的企业和开发者。

总的来说,HarmonyOS NEXT在分布式架构、高性能、安全可靠、轻量化设计以及生态丰富等方面都表现出了其独特优势,为用户提供了更加便捷、高效且安全的操作体验。如需了解更多关于HarmonyOS NEXT的信息,建议访问华为官方网站或相关开发者社区。

在这里插入图片描述

相关文章
|
7天前
【HarmonyOS Next开发】:ListItemGroup使用
通过使用ListItemGroup和AlphabetIndexer两种类型组件,实现带标题分类和右侧导航栏的页面
99 61
|
2天前
|
存储 JavaScript 开发工具
基于HarmonyOS 5.0(NEXT)与SpringCloud架构的跨平台应用开发与服务集成研究【实战】
本次的.HarmonyOS Next ,ArkTS语言,HarmonyOS的元服务和DevEco Studio 开发工具,为开发者提供了构建现代化、轻量化、高性能应用的便捷方式。这些技术和工具将帮助开发者更好地适应未来的智能设备和服务提供方式。
基于HarmonyOS 5.0(NEXT)与SpringCloud架构的跨平台应用开发与服务集成研究【实战】
|
5天前
|
安全 API 数据安全/隐私保护
自学记录HarmonyOS Next DRM API 13:构建安全的数字内容保护系统
在完成HarmonyOS Camera API开发后,我深入研究了数字版权管理(DRM)技术。最新DRM API 13提供了强大的工具,用于保护数字内容的安全传输和使用。通过学习该API的核心功能,如获取许可证、解密内容和管理权限,我实现了一个简单的数字视频保护系统。该系统包括初始化DRM模块、获取许可证、解密视频并播放。此外,我还配置了开发环境并实现了界面布局。未来,随着数字版权保护需求的增加,DRM技术将更加重要。如果你对这一领域感兴趣,欢迎一起探索和进步。
58 18
|
4天前
|
人工智能 自然语言处理 API
自学记录HarmonyOS Next的HMS AI API 13:语音合成与语音识别
在完成图像处理项目后,我计划研究HarmonyOS Next API 13中的AI语音技术,包括HMS AI Text-to-Speech和Speech Recognizer。这些API提供了强大的语音合成与识别功能,支持多语言、自定义语速和音调。通过这些API,我将开发一个支持语音输入与输出的“语音助手”原型应用,实现从语音指令解析到语音响应的完整流程。此项目不仅提高了应用的交互性,也为开发者提供了广阔的创新空间。未来,语音技术将在无障碍应用和智慧城市等领域展现巨大潜力。如果你也对语音技术感兴趣,不妨一起探索这个充满无限可能的领域。 (238字符)
61 11
|
5天前
|
存储 API 计算机视觉
自学记录HarmonyOS Next Image API 13:图像处理与传输的开发实践
在完成数字版权管理(DRM)项目后,我决定挑战HarmonyOS Next的图像处理功能,学习Image API和SendableImage API。这两个API支持图像加载、编辑、存储及跨设备发送共享。我计划开发一个简单的图像编辑与发送工具,实现图像裁剪、缩放及跨设备共享功能。通过研究,我深刻体会到HarmonyOS的强大设计,未来这些功能可应用于照片编辑、媒体共享等场景。如果你对图像处理感兴趣,不妨一起探索更多高级特性,共同进步。
59 11
|
7天前
|
传感器 测试技术 定位技术
HarmonyOS Next 模拟器安装与探索
HarmonyOS 5 的发布带来了许多新特性,尤其是 HarmonyOS Next 模拟器。本文将带你一步步了解如何安装和使用这个强大的工具,帮助你更好地进行开发,加速项目进展。通过 DevEco Studio 的 Device Manager,你可以轻松创建、配置并启动模拟器,模拟真实设备的效果,支持多窗口、跨设备测试等新特性。此外,模拟器还提供了虚拟传感器、GPS 模拟、音频输入等功能,极大地方便了开发和调试过程。掌握这些功能,能让你的开发更加高效便捷。
75 9
|
7天前
|
开发者
【HarmonyOS Next开发】用户文件访问
文件所有者为登录到该终端设备的用户,包括用户私有的图片、视频、音频、文档等。 应用对用户文件的创建、访问、删除等行为,需要提前获取用户授权,或由用户操作完成。
32 10
|
7天前
|
存储 JSON 测试技术
【HarmonyOS Next开发】云开发-云数据库(二)
实现了云侧和端侧的云数据库创建、更新、修改等操作。这篇文章实现调用云函数对云数据库进行增删改查。
27 9
|
7天前
【HarmonyOS Next开发】使用两层Scroll实现一天时间轴和事件卡片的层叠显示
实现某一天24小时的时间长度和当天事件的页面。
44 9
|
7天前
|
API 容器
【HarmonyOS Next开发】Navigation使用
Navigation是路由容器组件,包括单栏(Stack)、分栏(Split)和自适应(Auto)三种显示模式。适用于模块内和跨模块的路由切换。 在页面跳转时,应该使用页面路由router,在页面内的页面跳转时,建议使用Navigation达到更好的转场动效场景。
70 8