67.Harmonyos NEXT 图片预览组件之性能优化策略

news2025/3/15 15:54:51

温馨提示:本篇博客的详细代码已发布到 git : https://gitcode.com/nutpi/HarmonyosNext 可以下载运行哦!

Harmonyos NEXT 图片预览组件之性能优化策略

文章目录

  • Harmonyos NEXT 图片预览组件之性能优化策略
    • 效果预览
    • 一、性能优化概述
      • 1. 性能优化的关键指标
    • 二、懒加载实现
      • 1. CommonLazyDataSourceModel实现原理
      • 2. LazyForEach组件的应用
      • 3. 缓存控制策略
    • 三、渲染优化
      • 1. 矩阵变换优化
      • 2. 图片适配策略
      • 3. 渲染属性优化
    • 四、内存管理
      • 1. 资源释放策略
      • 2. 图片加载优化
    • 五、交互性能优化
      • 1. 事件处理优化
      • 2. 动画性能优化
    • 六、性能优化建议
      • 1. 图片资源优化
      • 2. 组件配置优化
      • 3. 监控与调优
    • 七、总结

效果预览

一、性能优化概述

图片预览组件在处理大量高清图片时,性能优化显得尤为重要。本文将详细介绍图片预览组件中采用的性能优化策略,包括懒加载实现、内存管理、渲染优化等方面,帮助开发者构建高性能的图片预览功能。

1. 性能优化的关键指标

在图片预览组件中,我们主要关注以下性能指标:

性能指标说明优化方向
内存占用图片加载和缓存占用的内存懒加载、资源释放
渲染性能图片显示和交互的流畅度矩阵变换、渲染优化
加载速度图片加载和切换的速度预加载、缓存策略
交互响应手势操作的响应速度事件处理优化

二、懒加载实现

1. CommonLazyDataSourceModel实现原理

图片预览组件使用CommonLazyDataSourceModel实现图片的懒加载,其核心原理是:

export class CommonLazyDataSourceModel<T> extends BasicDataSource<T> {
  private dataArray: T[] = [];

  public totalCount(): number {
    return this.dataArray.length;
  }

  public getData(index: number): T {
    return this.dataArray[index];
  }

  public clearAndPushAll(data: T[]): void {
    this.dataArray = [];
    this.dataArray.push(...data);
    this.notifyDataReload();
  }
}

懒加载数据源模型继承自BasicDataSource,实现了IDataSource接口,提供了数据变化通知机制。当数据发生变化时,会通知LazyForEach组件更新UI。

2. LazyForEach组件的应用

List({ scroller: this.listScroll, space: this.listSpace }) {
    LazyForEach(this.lazyImageList, (imageUrl: string, index: number) => {
        ListItem() {
            PicturePreviewImage({
                imageUrl: imageUrl,
                // 其他参数...
            })
        }
        .width("100%")
    })
}

LazyForEach组件只会渲染当前可见的图片项,而不是一次性加载所有图片,大大减少了内存占用和初始加载时间。

3. 缓存控制策略

.cachedCount(1)

通过设置List组件的cachedCount属性,控制缓存的图片数量,避免过多的内存占用。在实际应用中,可以根据设备性能和图片大小调整这个值。

三、渲染优化

1. 矩阵变换优化

图片预览组件使用matrix4矩阵变换实现图片的缩放和旋转,而不是直接修改图片尺寸,这种方式具有以下优势:

this.matrix = matrix4.identity().scale({
    x: this.imageScaleInfo.scaleValue,
    y: this.imageScaleInfo.scaleValue,
}).rotate({
    x: 0,
    y: 0,
    z: 1,
    angle: this.imageRotateInfo.currentRotate,
}).copy();
  1. 高效渲染:矩阵变换由GPU加速,性能更高
  2. 内存节约:不需要创建多个不同尺寸的图片实例
  3. 精确控制:可以实现精确的缩放和旋转效果

2. 图片适配策略

calcImageDefaultSize(imageWHRatio: number, windowSize: window.Size): image.Size {
    let width = 0
    let height = 0;
    if (imageWHRatio > windowSize.width / windowSize.height) {
        // 图片宽高比大于屏幕宽高比,图片默认以屏幕宽度进行显示
        width = windowSize.width;
        height = windowSize.width / imageWHRatio;
    } else {
        height = windowSize.height;
        width = windowSize.height * imageWHRatio;
    }
    return { width: width, height: height };
}

组件会根据图片和屏幕的宽高比,计算最适合的显示尺寸,避免不必要的缩放操作,提高渲染性能。

3. 渲染属性优化

Image(this.imageUrl)
    .width(this.imageWH === ImageFitType.TYPE_WIDTH ? $r("app.string.imageviewer_image_default_width") : undefined)
    .height(this.imageWH === ImageFitType.TYPE_HEIGHT ? $r("app.string.imageviewer_image_default_height") : undefined)
    .aspectRatio(this.imageWHRatio)
    .objectFit(ImageFit.Cover)
    .autoResize(false)
    .transform(this.matrix)
    .offset({
        x: this.imageOffsetInfo.currentX,
        y: this.imageOffsetInfo.currentY
    })

组件使用了多种渲染优化技术:

  1. 按需设置宽高:只设置一个维度,另一个通过aspectRatio自动计算
  2. 禁用自动调整大小:设置autoResize为false,避免不必要的布局计算
  3. 适当的objectFit模式:使用Cover模式确保图片能够正确显示

四、内存管理

1. 资源释放策略

resetCurrentImageInfo(): void {
    animateTo({
        duration: this.restImageAnimation
    }, () => {
        this.imageScaleInfo.reset();
        this.imageOffsetInfo.reset();
        this.imageRotateInfo.reset();
        this.matrix = matrix4.identity().copy();
    })
}

当图片切换时,组件会重置前一张图片的状态,释放不必要的资源,避免内存泄漏。

2. 图片加载优化

.onComplete((event: ImageLoadResult) => {
    if (event) {
        this.initCurrentImageInfo(event)
    }
})

组件在图片加载完成后才初始化相关信息,避免在加载过程中进行不必要的计算,提高性能。

五、交互性能优化

1. 事件处理优化

PanGesture({ fingers: 1 })
    .onActionUpdate((event: GestureEvent) => {
        if (this.imageWH != ImageFitType.TYPE_DEFAULT) {
            if (this.eventOffsetX != event.offsetX || event.offsetY != this.eventOffsetY) {
                this.eventOffsetX = event.offsetX;
                this.eventOffsetY = event.offsetY;
                this.setCrossAxis(event);
                this.setPrincipalAxis(event);
            }
        }
    })

组件通过比较前后事件的偏移量,避免处理重复的事件,减少不必要的计算和渲染。

2. 动画性能优化

export function runWithAnimation(fn: Function, duration: number = 300) {
    animateTo({
        duration: duration,
        curve: Curve.Ease,
        iterations: 1,
        playMode: PlayMode.Normal,
    }, fn);
}

组件使用animateTo API实现平滑的动画效果,该API由系统优化,性能更高。同时,通过设置合理的动画参数,避免过于复杂的动画效果。

六、性能优化建议

1. 图片资源优化

在使用图片预览组件时,建议对图片资源进行优化:

  1. 合适的分辨率:根据显示需求选择合适的图片分辨率,避免过大的图片
  2. 图片压缩:使用适当的压缩算法减小图片文件大小
  3. 图片格式:选择高效的图片格式,如WebP、HEIF等

2. 组件配置优化

根据实际需求调整组件配置,提高性能:

  1. 缓存数量:根据设备性能和内存情况调整cachedCount值
  2. 预加载策略:根据用户行为预测可能查看的图片,提前加载
  3. 动画参数:调整动画持续时间和曲线,平衡流畅度和性能

3. 监控与调优

在实际应用中,建议进行性能监控和调优:

  1. 内存监控:监控应用内存使用情况,及时发现内存泄漏
  2. 性能分析:使用性能分析工具找出性能瓶颈
  3. 用户反馈:收集用户反馈,针对性地进行优化

七、总结

图片预览组件通过懒加载实现、矩阵变换优化、内存管理和交互性能优化等策略,实现了高性能的图片预览功能。这些优化策略不仅提高了组件的性能,还改善了用户体验。

在实际应用中,开发者可以根据具体需求和设备性能,调整组件配置和优化策略,进一步提高性能。同时,持续的性能监控和调优也是保持组件高性能的关键。

通过本文介绍的性能优化策略,开发者可以更好地理解和使用图片预览组件,构建高性能的图片预览功能。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2315530.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Windows下安装Git客户端

① 官网地址&#xff1a;https://git-scm.com/。 ② Git的优势 大部分操作在本地完成&#xff0c;不需要联网&#xff1b;完整性保证&#xff1b;尽可能添加数据而不是删除或修改数据&#xff1b;分支操作非常快捷流畅&#xff1b;与Linux 命令全面兼容。 ③ Git的安装 从官网…

SAP IBP for Supply Chain Certification Guide (Parag Bakde, Rishabh Gupta)

SAP IBP for Supply Chain Certification Guide (Parag Bakde, Rishabh Gupta)

如何处理PHP中的日期和时间问题

如何处理PHP中的日期和时间问题 在PHP开发中&#xff0c;日期和时间的处理是一个常见且重要的任务。无论是记录用户操作时间、生成时间戳&#xff0c;还是进行日期计算&#xff0c;PHP提供了丰富的函数和类来帮助开发者高效处理这些需求。本文将详细介绍如何在PHP中处理日期和…

TDengine 使用最佳实践

简介 阅读本文档需要具备的基础知识&#xff1a; Linux系统的基础知识&#xff0c;及基本命令网络基础知识&#xff1a;TCP/UDP、http、RESTful、域名解析、FQDN/hostname、hosts、防火墙、四层/七层负载均衡 本文档的阅读对象有&#xff1a;架构师、研发工程师&#xff0c;…

Spring、Spring Boot、Spring Cloud 的区别与联系

1. Spring 框架 定位&#xff1a;轻量级的企业级应用开发框架&#xff0c;核心是 IoC&#xff08;控制反转&#xff09; 和 AOP&#xff08;面向切面编程&#xff09;。 核心功能&#xff1a; 依赖注入&#xff08;DI&#xff09;&#xff1a;通过 Autowired、Component 等注解…

AutoGen-构建问答智能体

概述 如https://github.com/microsoft/autogen所述&#xff0c;autogen是一多智能体的框架&#xff0c;属于微软旗下的产品。 依靠AutoGen我们可以快速构建出一个多智能体应用&#xff0c;以满足我们各种业务场景。 环境说明 python&#xff0c;3.10AutoGen&#xff0c;0.4.2…

C语言实现括号匹配检查及栈的应用详解

目录 栈数据结构简介 C语言实现栈 栈的初始化 栈的销毁 栈的插入 栈的删除 栈的判空 获取栈顶数据 利用栈实现括号匹配检查 总结 在编程中&#xff0c;经常会遇到需要检查括号是否匹配的问题&#xff0c;比如在编译器中检查代码的语法正确性&#xff0c;或者在…

阿里云魔笔低代码应用开发平台快速搭建教程

AI低代码&#xff0c;大模型时代应用开发新范式 什么是魔笔 介绍什么是魔笔低代码应用开发平台。 魔笔是一款面向全端&#xff08;Web、H5、全平台小程序、App&#xff09;场景的模型驱动低代码开发平台&#xff0c;提供一站式的应用全生命周期管理&#xff0c;包括可视化开发…

A Survey on Mixture of Experts 混合专家模型综述(第二部分:混合专家系统设计)

A Survey on Mixture of Experts 混合专家模型综述 (第一部分&#xff1a;混合专家算法设计) A Survey on Mixture of Experts arxiv github&#xff1a;A-Survey-on-Mixture-of-Experts-in-LLMs ​ ​ ​ 5 System Design of Mixture of Experts While ​Mixture of Exper…

docker python:latest镜像 允许ssh远程

跳转到家目录 cd创建pythonsshdockerfile mkdir pythonsshdockerfile跳转pythonsshdockerfile cd pythonsshdockerfile创建Dockerfile文件 vim Dockerfile将Dockerfile的指令复制到文件中 # 使用 python:latest 作为基础镜像 # 如果我的镜像列表中没有python:latest镜像&…

Aim Robotics电动胶枪:机器人涂胶点胶的高效解决方案

在自动化和智能制造领域&#xff0c;机器人技术的应用越来越广泛&#xff0c;而涂胶和点胶作为生产过程中的重要环节&#xff0c;也逐渐实现了自动化和智能化。Aim Robotics作为一家专注于机器人技术的公司&#xff0c;其推出的电动胶枪为这一领域带来了高效、灵活且易于操作的…

【HDLbits--分支预测器简单实现】

HDLbits--分支预测器简单实现 1 timer2.branche predicitors3.Branch history shift4.Branch direction predictor 以下是分支预测器的简单其实现&#xff1b; 1 timer 实现一个计时器&#xff0c;当load1’b1时&#xff0c;加载data进去&#xff0c;当load1’b0时进行倒计时&…

Linux--操作系统/进程

ok&#xff0c;我们今天学习linux中的操作系统和进程 1. 冯诺依曼体系 我们常⻅的计算机&#xff0c;如笔记本。我们不常⻅的计算机&#xff0c;如服务器&#xff0c;⼤部分都遵守冯诺依曼体系。 内存是CPU和外设之间的一个巨大的缓存&#xff01; 截⾄⽬前&#xff0c;我们…

Java面试八股—Redis篇

一、Redis的使用场景 &#xff08;一&#xff09;缓存 1.Redis使用场景缓存 场景&#xff1a;缓存热点数据&#xff08;如用户信息、商品详情&#xff09;&#xff0c;减少数据库访问压力&#xff0c;提升响应速度。 2.缓存穿透 正常的访问是&#xff1a;根据ID查询文章&…

Web后端开发之Maven

Maven Mven是apache旗下的一个开源项目&#xff0c;用来管理和构建java项目的工具。 通过一小段描述信息来管理项目。 Maven的作用 1.依赖管理&#xff1a;方便快捷的管理项目依赖的资源&#xff08;jar包&#xff09;&#xff0c;避免版本冲突问题 以前用某个jar包需要下载…

there are no enabled repos

我做了两个操作 第一个操作&#xff1a; 1.先在本地电脑&#xff0c;也就是在我们电脑的桌面上下载 https://repo.huaweicloud.com/repository/conf/CentOS-7-reg.repo 2.在CentOS 创建etc文件夹 3在etc文件夹内创建yum.repos.d文件夹 4.将下载好的repo 黏贴到yum.repos.d…

OpenEuler-22.03-LTS上利用Ansible轻松部署MySQL 5.7

一、需求 使用ansible自动化部署mysql二进制部署mysql部署mysql并创建JDBC用户 二、环境信息 本文涉及的代码&#xff0c;配置文件地址&#xff1a; 链接&#xff1a;百度网盘 请输入提取码 提取码&#xff1a;1g6y 软件名称版本备注Ansible2.9.27All modules — Ansible Doc…

前端无限滚动内容自动回收技术详解:原理、实现与优化

文章目录 一、核心需求与技术挑战1.1 无限滚动的问题症结1.2 自动回收的三大目标 二、技术实现原理2.1 虚拟滚动核心机制2.2 关键技术指标 三、完整实现方案3.1 基础HTML结构3.2 CSS关键样式3.3 JavaScript核心逻辑3.3.1 滚动控制器3.3.2 动态尺寸处理 四、性能优化策略4.1 内存…

如何在Ubuntu上构建编译LLVM和ISPC,以及Ubuntu上ISPC的使用方法

之前一直在 Mac 上使用 ISPC&#xff0c;奈何核心/线程太少了。最近想在 Ubuntu 上搞搞&#xff0c;但是 snap 安装的 ISPC不知道为什么只能单核&#xff0c;很奇怪&#xff0c;就想着编译一下&#xff0c;需要 Clang 和 LLVM。但是 Ubuntu 很搞&#xff0c;他的很多软件版本是…

【MySQL】表的约束(上)

文章目录 表的约束什么是表的约束空属性默认值列描述&#xff08;comment&#xff09;零填充&#xff08;zerofill&#xff09;主键 总结 表的约束 什么是表的约束 表的约束&#xff08;Constraints&#xff09;是数据库表中的规则&#xff0c;用于限制存储的数据&#xff0c…