当前位置: 首页 > article >正文

HarmonyOS 5.0应用开发——全局自定义弹出框openCustomDialog

【高心星出品】

文章目录

      • 全局自定义弹出框openCustomDialog
        • 案例
        • 开发步骤
        • 完整代码

全局自定义弹出框openCustomDialog

CustomDialog是自定义弹出框,可用于广告、中奖、警告、软件更新等与用户交互响应操作。开发者可以通过CustomDialogController类显示自定义弹出框。

但是使用起来有很多问题,不支持动态创建也不支持动态刷新,在相对较复杂的应用场景中推荐使用UIContext中获取到的PromptAction对象提供的openCustomDialog接口来实现自定义弹出框。

openCustomDialog(传参为ComponentContent形式):通过ComponentContent封装内容可以与UI界面解耦,调用更加灵活,可以满足开发者的封装诉求。拥有更强的灵活性,弹出框样式是完全自定义的,且在弹出框打开之后可以使用updateCustomDialog方法动态更新弹出框的一些参数。

案例

下面将写一个案例,点击按钮弹出自定义对话框,并且可以动态修改对话框的位置和内容。

运行结果

在这里插入图片描述

开发步骤

全局对话框弹出工具

里面只需要UIContext,ComponentContent和对话框配置option。

里面有打开对话框,关闭对话框和更新对话框的方法。

class customdialogutil {
  // UI上下文环境
  private static uicontext: UIContext

  public static setuicontext(value: UIContext) {
    customdialogutil.uicontext = value
  }

  // 对话框显示的内容
  private static content: ComponentContent<Object>

  public static setcontent(value: ComponentContent<object>) {
    customdialogutil.content = value
  }

  // 弹出对话框的配置
  private static option: promptAction.ShowDialogOptions

  public static setoption(value: promptAction.ShowDialogOptions) {
    customdialogutil.option = value
  }

  // 打开弹出框
  static open() {
    customdialogutil.uicontext.getPromptAction()
      .openCustomDialog(customdialogutil.content, customdialogutil.option)
      .catch((err: Error) => {
        console.error('gxxt ', err.message)
      })
  }

  // 关闭弹出框
  static close() {
    customdialogutil.uicontext.getPromptAction().closeCustomDialog(customdialogutil.content).catch((err: Error) => {
      console.error('gxxt ', err.message)
    })
  }

  // 更新弹出框内容或这样式
  static update(nopt: promptAction.ShowDialogOptions) {
    customdialogutil.uicontext.getPromptAction()
      .updateCustomDialog(customdialogutil.content, nopt)
      .catch((err: Error) => {
        console.error('gxxt ', err.message)
      })
  }
}

生成对话框界面的构建函数

interface param {
  message: string
  updck: () => void
  closeck: () => void
}

@Builder
function dialogcontent(p: param) {
  Column({ space: 20 }) {
    Text(p.message).fontSize(20).fontWeight(FontWeight.Bolder)
    Row() {
      Button('更新').onClick(p.updck)
      Button('关闭').onClick(p.closeck)
    }
    .justifyContent(FlexAlign.SpaceAround)
    .width('100%')
  }
  .padding(20)
  .backgroundColor(Color.White)
  .width('80%')
  .borderRadius(20)
}

页面代码

@Entry
@Component
struct CustomdialogPage {
  build() {
    Column() {
      Button('弹出框')
        .width('60%')
        .onClick(() => {
          // 设置ui上下文环境
          customdialogutil.setuicontext(this.getUIContext())
          // 第一个builder构建函数生成的compoentcontent
          let content: ComponentContent<param> =
            new ComponentContent<param>(this.getUIContext(), wrapBuilder<[param]>(dialogcontent), {
              message: '自定义对话框内容1', updck: () => {
                // 更新对话框的位置
                customdialogutil.update({ alignment: DialogAlignment.Top, offset: { dy: 100, dx: 0 } })
              }, closeck: () => {
                // 关闭对话框
                customdialogutil.close()
              }
            })
          // 设置第一个构建函数的componentcontent
          customdialogutil.setcontent(content)
          customdialogutil.setoption({})
          // 打开对话框
          customdialogutil.open()
        })

    }
    .height('100%')
    .width('100%')
    .justifyContent(FlexAlign.Center)
  }
}
完整代码
import { ComponentContent, promptAction, typeNode } from '@kit.ArkUI'

class customdialogutil {
  // UI上下文环境
  private static uicontext: UIContext

  public static setuicontext(value: UIContext) {
    customdialogutil.uicontext = value
  }

  // 对话框显示的内容
  private static content: ComponentContent<Object>

  public static setcontent(value: ComponentContent<object>) {
    customdialogutil.content = value
  }

  // 弹出对话框的配置
  private static option: promptAction.ShowDialogOptions

  public static setoption(value: promptAction.ShowDialogOptions) {
    customdialogutil.option = value
  }

  // 打开弹出框
  static open() {
    customdialogutil.uicontext.getPromptAction()
      .openCustomDialog(customdialogutil.content, customdialogutil.option)
      .catch((err: Error) => {
        console.error('gxxt ', err.message)
      })
  }

  // 关闭弹出框
  static close() {
    customdialogutil.uicontext.getPromptAction().closeCustomDialog(customdialogutil.content).catch((err: Error) => {
      console.error('gxxt ', err.message)
    })
  }

  // 更新弹出框内容或这样式
  static update(nopt: promptAction.ShowDialogOptions) {
    customdialogutil.uicontext.getPromptAction()
      .updateCustomDialog(customdialogutil.content, nopt)
      .catch((err: Error) => {
        console.error('gxxt ', err.message)
      })
  }
}

interface param {
  message: string
  updck: () => void
  closeck: () => void
}

@Builder
function dialogcontent(p: param) {
  Column({ space: 20 }) {
    Text(p.message).fontSize(20).fontWeight(FontWeight.Bolder)
    Row() {
      Button('更新').onClick(p.updck)
      Button('关闭').onClick(p.closeck)
    }
    .justifyContent(FlexAlign.SpaceAround)
    .width('100%')
  }
  .padding(20)
  .backgroundColor(Color.White)
  .width('80%')
  .borderRadius(20)
}


@Entry
@Component
struct CustomdialogPage {
  build() {
    Column() {
      Button('弹出框')
        .width('60%')
        .onClick(() => {
          // 设置ui上下文环境
          customdialogutil.setuicontext(this.getUIContext())
          // 第一个builder构建函数生成的compoentcontent
          let content: ComponentContent<param> =
            new ComponentContent<param>(this.getUIContext(), wrapBuilder<[param]>(dialogcontent), {
              message: '自定义对话框内容1', updck: () => {
                // 更新对话框的位置
                customdialogutil.update({ alignment: DialogAlignment.Top, offset: { dy: 100, dx: 0 } })
              }, closeck: () => {
                // 关闭对话框
                customdialogutil.close()
              }
            })
          // 设置第一个构建函数的componentcontent
          customdialogutil.setcontent(content)
          customdialogutil.setoption({})
          // 打开对话框
          customdialogutil.open()
        })

    }
    .height('100%')
    .width('100%')
    .justifyContent(FlexAlign.Center)
  }
}
        customdialogutil.setcontent(content)
          customdialogutil.setoption({})
          // 打开对话框
          customdialogutil.open()
        })

    }
    .height('100%')
    .width('100%')
    .justifyContent(FlexAlign.Center)
  }
}

http://www.kler.cn/a/537852.html

相关文章:

  • 在 C++ 中使用 Protocol Buffers(protobuf)
  • 【通俗易懂说模型】反向传播(附多元回归与Softmax函数)
  • 微信小程序如何使用decimal计算金额
  • 使用云效解决docker官方镜像拉取不到的问题
  • Redis深入学习
  • DeepSeek底层揭秘——多模态融合引擎
  • 蓝桥与力扣刷题(19 删除链表的倒数第N个结点)
  • 刚发布的nodejs 23提供了哪些新能力
  • 高效Android Studio编程:快捷键汇总
  • IDEA编写SpringBoot项目时使用Lombok报错“找不到符号”的原因和解决
  • I2C协议—读写EEPROM(24Cxx为例)
  • VSCode 换行符问题
  • Deepseek的起源与发展
  • (六)QT——布局&常用控件——基本的用户输入界面
  • HTTP报文格式
  • 蓝桥杯---力扣题库第38题目解析
  • html css网页制作成品——HTML+CSS爷爷不泡茶的茶网页设计(7页)附源码
  • IDEA安装离线插件(目前提供了MavenHelper安装包)
  • npm中央仓库
  • pycharm ai插件
  • element-plus 解决el-dialog背后的页面滚动问题,及其内容有下拉框出现错位问题
  • 21.[前端开发]Day21-HTML5新增内容-CSS函数-BFC-媒体查询
  • < 评论 > 阿里云 与 腾讯云 国内的轻量应用服务器(VPS)产品对比
  • 【韩顺平linux】部分上课笔记整理
  • 星网锐捷 DMB-BS LED屏信息发布系统taskexport接口处存在敏感信息泄露
  • 机器学习专业毕业设计选题灵感集锦:选题建议