#鸿蒙通关秘籍#如何解决HarmonyOS中分屏模式切换时的Bug?

HarmonyOS
2024-12-03 11:05:55
1195浏览
收藏 0
回答 1
回答 1
按赞同
/
按时间
CLI风轨迹

在HarmonyOS中进行导航模式切换时,可能会出现动画冲突的问题。可以通过设置navBarWidth和动态更改其值来适配全屏模块。同时,在切换模块时,可控制是否显示动画来避免Bug。以下代码展示了如何在全屏音乐播放器案例中处理该问题:

// EntryView.ets
@Provide('isFullScreen') isFullScreen: string = '50%';

Navigation(this.pageStack) {
  ...
}
.backgroundColor($r('app.color.main_background_color'))
.hideTitleBar(true)
.navBarWidth(this.isFullScreen)
.navDestination(this.pageMap)
.mode(NavigationMode.Auto)

// MusicPlayerInfoComp.ets
@Consume('isFullScreen') isFullScreen: string;

aboutToAppear(): void {
  ...
  animateTo({
    duration: 400,
    curve: Curve.EaseInOut,
  }, () => {
    this.isFullScreen = '0.01%';
  })
  ...
}

//DynamicsRouter.ets
public static async push(routerInfo: RouterInfo, param?: string): Promise<void> {
  ...
  let isNeedFullScreen: boolean = true;
  ...
  await import(moduleName).then((result: ESObject) => {
    ...
    if (FullScreenArray.includes(moduleName)) {
      isNeedFullScreen = false;
    }
  });
  if (isImportSucceed) {
    ...
    DynamicsRouter.getNavPathStack().pushPath({ name: builderName, param: param }, isNeedFullScreen);
    ...
  }
}
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.
  • 31.
  • 32.
  • 33.
  • 34.
  • 35.
  • 36.
  • 37.
  • 38.
  • 39.
  • 40.
  • 41.
  • 42.
  • 43.
分享
微博
QQ
微信
回复
2024-12-03 11:48:10


相关问题
HarmonyOS 如何关闭分屏模式
1034浏览 • 1回复 待解决
HarmonyOS 如何禁用小窗和分屏模式
1228浏览 • 1回复 待解决
HarmonyOS 分屏模式界面如何适配
734浏览 • 1回复 待解决
HarmonyOS 怎么禁用分屏模式
547浏览 • 1回复 待解决
HarmonyOS分屏模式和小窗口模式适配
1957浏览 • 1回复 待解决