介绍
本示例是合理处理高负载组件的渲染文章的示例代码,主要讲解如何通过DisplaySync优化高负载组件的渲染,减少丢帧情况的发生。
效果图预览
使用说明
- 通过组件复用,加载10年的日历数据,每个复用组件都在aboutToReuse接口中加载一个月的数据。
- 通过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优化列表数据加载。
-
计算未来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学习资料←点击领取!(安全链接,放心点击)