【HarmonyOS NEXT】在 HarmonyOS NEXT 中实现优雅的加载动画

【HarmonyOS NEXT】在 HarmonyOS NEXT 中实现优雅的加载动画

在移动应用开发中,加载动画是提升用户体验的重要工具。在应用程序处理数据或加载页面时,为用户提供视觉反馈尤为关键。在这篇博客中,我们将探讨如何在 HarmonyOS NEXT 中使用 Stack 布局结合 LoadingProgress 组件来实现流畅的加载动画。

为什么使用加载动画?

加载动画在应用体验中扮演着重要角色,通过动态提示用户进度状态,可以有效提升应用的响应性感知。特别是在网络环境不稳定或数据繁重的场景下,加载动画不仅能缓解等待时的焦虑,还能美化用户界面,增加应用的整体吸引力。

HarmonyOS NEXT 技术栈

在 HarmonyOS NEXT 中,开发者可利用 Stack 布局和 LoadingProgress 组件轻松实现重叠效果,进而实现加载动画的需求。

具体实现

以下是如何实现加载动画的详细步骤。

定义加载状态

首先,我们需要定义一个状态变量以追踪加载状态。在页面未加载完成之前,我们需要显示加载动画,而一旦加载完成,我们便隐藏这个动画。

typescript 复制代码
@State loaded: boolean = false;

这里的 loaded 变量初始值为 false,表示页面尚未加载完成。

利用 Stack 布局

Stack 是一个常用的布局工具,它允许组件的重叠显示。在实现过程中,我们利用 Stack 布局将 Web 组件与 LoadingProgress 组件放置在一起,并根据加载状态切换显示状态。

typescript 复制代码
build() {
  Stack() {
    // Web组件用于展示网页内容
    Web({ 
      src: $rawfile("homePage/index.html"), 
      controller: this.controller.getWebViewController() 
    })
      .javaScriptAccess(true)
      .javaScriptProxy(this.controller.getJavaScriptProxy())
      .onAlert((event) => {
        return false;
      })
      .domStorageAccess(true)
      .zoomAccess(true)
      .fileAccess(true)
      .mixedMode(MixedMode.All)
      .height('100%')
      .width('100%')
      .onPageEnd((event) => {
        if (event) {
          this.loaded = true; // 页面加载完成
        }
      });

    // 显示加载动画
    if (!this.loaded) {
      LoadingProgress()
        .height(180)
        .color('#cd0401'); // 红色的加载指示器
    }
  }
}
关键逻辑详解
  1. Web 组件 :负责加载网页内容。我们通过 onPageEnd 事件监听页面加载状态,一旦加载完毕,将 loaded 设为 true

  2. LoadingProgress 组件 :在 loadedfalse 时显示。当页面结束加载,状态变为 true 后,LoadingProgress 就会消失不再渲染。

  3. Stack 布局 :这个布局允许我们将 WebLoadingProgress 组件堆叠。由于 LoadingProgress 在上方,当 loadedfalse 时,它会覆盖在 Web 组件之上。

相关推荐
不羁的木木28 分钟前
《HarmonyOS底部页签-沉浸光感组件实战》基础入门:认识HdsTabs容器与核心配置
华为·harmonyos
不羁的木木43 分钟前
《HarmonyOS技术精讲》三:记忆链接 ── 跨场景数据融合
pytorch·华为·harmonyos
2501_919749031 小时前
鸿蒙 Flutter 实战:image_crop 0.4.1 适配 3.27-ohos 全流程
flutter·华为·harmonyos
祭曦念1 小时前
鸿蒙应用的生命周期与页面跳转:从入门到实战
华为·harmonyos
轻口味1 小时前
HarmonyOS 6.1.1 全栈实战录 - 88 实战 Ability Kit 启动生命周期预热与快照恢复机
华为·harmonyos·鸿蒙
Goway_Hui2 小时前
【鸿蒙原生应用开发--ArkUI--013】Exercise-tracker 运动记录应用开发教程
华为·harmonyos
想你依然心痛2 小时前
HarmonyOS 6(API 23)实战:基于悬浮导航、沉浸光感与HMAF的“图谱智脑“——PC端AI智能体沉浸式知识图谱构建工作台
人工智能·ar·知识图谱·harmonyos·智能体
想你依然心痛2 小时前
HarmonyOS 6(API 23)实战:基于悬浮导航、沉浸光感与HMAF的“律界智脑“——PC端AI智能体沉浸式法律文档智能审查工作台
人工智能·华为·ar·harmonyos·智能体
特立独行的猫a3 小时前
鸿蒙 PC 平台 Python 第三方库移植全景指南
python·华为·harmonyos·三方库移植·鸿蒙pc
大雷神3 小时前
第31篇|位置信息写入照片记录:为什么拍照时要带上地点
harmonyos