HarmonyOS 自定义弹窗在页面中显示时,如何防止用户侧滑关闭自定义弹窗

HarmonyOS
17h前
浏览
收藏 0
回答 1
待解决
回答 1
按赞同
/
按时间
superinsect

目前想要实现防止用户侧滑关闭自定义弹窗的效果需要基于Navigation实现自定义弹窗,然后设置.onBackPressed((): boolean => true)

//demo
// Index.ets
@Component
struct Dialog01 {

  @Consume('pageInfos') pageInfos: NavPathStack;

  build() {
    NavDestination() {
      Stack() {
        Column()
          .width('100%')
          .height('100%')
          .backgroundColor(Color.Gray)
          .opacity(0.1)

        // Add controls for business processing
        Column() {
          Text('Dialog01')
            .fontSize(30)
            .fontWeight(2)
        }
        .padding(10)
        .width(250)
        .backgroundColor(Color.White)
        .borderRadius(10)
      }
    }
    .onBackPressed((): boolean => true)
    .hideTitleBar(true)
    // Set the mode property of this NavDestination to DIALOG
    .mode(NavDestinationMode.DIALOG)
  }
}

@Entry
@Component
struct Index {
  @Provide('pageInfos') pageInfos: NavPathStack = new NavPathStack()
  isLogin: boolean = false;

  @Builder
  PagesMap(name: string) {
    if (name == 'Dialog01') {
      Dialog01()
    }
  }

  build() {
    Navigation(this.pageInfos) {
      Button('push Dialog01')
        .width('80%')
        .onClick(() => {
          this.pageInfos.pushPathByName('Dialog01', '');
        })

    }
    .mode(NavigationMode.Stack)
    .titleMode(NavigationTitleMode.Mini)
    .title('主页')
    .navDestination(this.PagesMap)
  }
}
分享
微博
QQ
微信
回复
14h前
相关问题
自定义弹窗自定义转场动画
1170浏览 • 1回复 待解决
如何自定义弹窗再次弹窗
2323浏览 • 1回复 待解决
HarmonyOS 自定义弹窗不能显示问题
53浏览 • 1回复 待解决
弹窗打开、关闭动画是否支持自定义
2409浏览 • 1回复 待解决
HarmonyOS 自定义弹窗选择
398浏览 • 1回复 待解决
HarmonyOS 自定义弹窗封装后不显示
382浏览 • 1回复 待解决
HarmonyOS 如何封装自定义弹窗
0浏览 • 0回复 待解决
自定义弹窗的变量如何传递给页面
2739浏览 • 1回复 待解决