OpenHarmony教程指南—如何通过DisplaySync优化高负载组件的渲染,减少丢帧情况的发生。

650 篇文章 7 订阅
645 篇文章 7 订阅

介绍

本示例是合理处理高负载组件的渲染文章的示例代码,主要讲解如何通过DisplaySync优化高负载组件的渲染,减少丢帧情况的发生。

效果图预览

使用说明

  1. 通过组件复用,加载10年的日历数据,每个复用组件都在aboutToReuse接口中加载一个月的数据。
  2. 通过DisplaySync的帧回调接口,在组件复用时将一个月的数据拆成多份,并在每一帧中加载其中一份数据,减少每一帧绘制的组件数量,减少丢帧现象的发生。

实现思路

普通数据加载。

1.计算未来10年的日历数据(包括农历日期),放入数组中待用。

initCalenderData() {
  hiTraceMeter.startTrace('push_data_direct', 1);
  for (let k = this.currentYear; k < 2035; k++) {
    ...
  }
  hiTraceMeter.finishTrace('push_data_direct', 1);
}

2.通过List组件,在组件复用的aboutToReuse接口中直接加载数据

...
List() {
  LazyForEach(this.contentData, (monthItem: Month) => {
    ListItem() {
      ItemView({
        monthItem: monthItem,
        currentMonth: this.currentMonth,
        currentDay: this.currentDay
      }).reuseId("reuse_id_" + monthItem.days.length.toString())
    }
  })
}
...

@Reusable
@Component
struct ItemView {
  ...
  aboutToReuse(params: Record<string, Object>): void {
    hiTraceMeter.startTrace("reuse_" + (params.monthItem as Month).month, 1);
    this.monthItem = params.monthItem as Month;
    hiTraceMeter.finishTrace("reuse_" + (params.monthItem as Month).month, 1);
  }
  ...
  build() {
    Flex({ wrap: FlexWrap.Wrap }) {
      ...
    }
  }
}

通过DisplaySync优化列表数据加载

  1. 计算未来10年的日历数据(包括农历日期),放入数组中待用。

initCalenderData() {
  hiTraceMeter.startTrace('push_data_direct', 1);
  for (let k = this.currentYear; k < 2035; k++) {
    ...
  }
  hiTraceMeter.finishTrace('push_data_direct', 1);
}

2.通过List组件,使用组件复用的aboutToReuse接口将数据放入一个数组中,不直接修改组件数据

@Reusable
@Component
struct ItemView {
   ...
   aboutToReuse(params: Record<string, Object>): void {
      hiTraceMeter.startTrace("reuse_" + (params.monthItem as Month).month, 1);
      this.temp.push(params.monthItem as Month);
      hiTraceMeter.finishTrace("reuse_" + (params.monthItem as Month).month, 1);
   }
      ...
}

3.通过DisplaySync的帧回调接口,遍历数组,将每一条数据都拆分成多份,分别放到单独一帧中加载

...
aboutToAppear(): void {
  hiTraceMeter.startTrace("appear_", 1);
  this.displaySync = displaySync.create();
  const range: ExpectedFrameRateRange = {
    expected: 120,
    min: 60,
    max: 120
  };
  this.displaySync.setExpectedFrameRateRange(range);
  this.displaySync.on("frame", () => {
    // 拆分数据,每次只加载5条数据
    ...
  });
  this.displaySync.start();
  ...
  hiTraceMeter.finishTrace("appear_", 1);
}
...

高性能知识点

通过DisplaySync的帧回调接口,将需要加载的大数据拆分成多份小数据,将一份小数据放在一帧中加载,减少每一帧绘制的组件数,从而减少掉帧现象的发生。

工程结构&模块类型

pulltorefreshnews                                  // har类型
|---pages
|---|---GetDate.ets                                // 获取日期数据
|---|---MainPage.ets                               // 首页
|---|---MonthDataSource.ets                        // 懒加载数据类型
|---|---ReuseFramePage.ets                         // 通过DisplaySync优化的页面
|---|---ReusePage.ets                              // 正常加载数据的页面

最后

如果你想快速提升鸿蒙技术,那么可以直接领取这份包含了:【OpenHarmony多媒体技术、Stage模型、ArkUI多端部署、分布式应用开发、音频、视频、WebGL、Napi组件、OpenHarmony内核、Harmony南向开发、鸿蒙项目实战】等技术知识点。

鸿蒙Next全套VIP学习资料←点击领取!(安全链接,放心点击

1.鸿蒙核心技术学习路线

2.大厂面试必问面试题

3.鸿蒙南向开发技术

 4.鸿蒙APP开发必备

 5.HarmonyOS Next 最新全套视频教程

 6.鸿蒙生态应用开发白皮书V2.0PDF

这份全套完整版的学习资料已经全部打包好,朋友们如果需要可以点击鸿蒙Next全套VIP学习资料免费领取(安全链接,放心点击

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值