HarmonyOS鸿蒙Next中CustomDialog位置问题

发布于 1周前 作者 h691938207 来自 鸿蒙OS

HarmonyOS鸿蒙Next中CustomDialog位置问题

@State iconButtonLocation: IconButtonLocation = new IconButtonLocation(0, 0);

vehicleControlMenuController: CustomDialogController = new CustomDialogController({ builder: VehicleControlMenu({ menuList: this.vehicleControlMenuList, click: this.popVehicleControlItem.bind(this), }), customStyle: true, isModal: true, showInSubWindow: true, offset: { dx: this.iconButtonLocation.locationX, dy: this.iconButtonLocation.locationY } });

如上,通过修改iconButtonLocation.locationX和iconButtonLocation.locationY的值并不能更新VehicleControlMenu位置 在UI加载后会初始化vehicleControlMenuController offset的位置如果想要更新 VehicleControlMenu位置 通过修改iconButtonLocation.locationX和iconButtonLocation.locationY的值并不能更新VehicleControlMenu位置 如何修改VehicleControlMenu位置


更多关于HarmonyOS鸿蒙Next中CustomDialog位置问题的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html

3 回复

参考demo如下:

import { BusinessError } from '@ohos.base';
import { ComponentContent } from "@ohos.arkui.node";

class Params {
  text: string = "";

  constructor(text: string) {
    this.text = text;
  }
}

@Builder
function buildText(params: Params) {
  Column() {
    Text(params.text)
      .fontSize(50)
      .fontWeight(FontWeight.Bold)
      .margin({bottom: 36})
  }.backgroundColor('#FFF0F0F0')
}

@Entry
@Component
struct Index {
  @State message: string = "hello"

  build() {
    Row() {
      Column() {
        Button("click me")
          .onClick(() => {
            let uiContext = this.getUIContext();
            let promptAction = uiContext.getPromptAction();
            let contentNode = new ComponentContent(uiContext, wrapBuilder(buildText), new Params(this.message));

            try {
              promptAction.openCustomDialog(contentNode);
            } catch (error) {
              let message = (error as BusinessError).message;
              let code = (error as BusinessError).code;
              console.error(`OpenCustomDialog args error code is ${code}, message is ${message}`);
            };

            setTimeout(() => {
              try {
                promptAction.updateCustomDialog(contentNode, { alignment: DialogAlignment.CenterEnd });
              } catch (error) {
                let message = (error as BusinessError).message;
                let code = (error as BusinessError).code;
                console.error(`updateCustomDialog args error code is ${code}, message is ${message}`);
              };
            }, 2000); //20318211602635624377313830322
          })
      }
      .width('100%')
      .height('100%')
    }
    .height('100%')
  }
}

具体可参考链接如下: https://gitee.com/openharmony/docs/blob/master/zh-cn/application-dev/reference/apis-arkui/js-apis-arkui-UIContext.md#updatecustomdialog12

更多关于HarmonyOS鸿蒙Next中CustomDialog位置问题的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html


在HarmonyOS鸿蒙Next中,CustomDialog的位置可以通过设置其布局参数来控制。CustomDialog继承自Dialog,因此可以使用WindowManager.LayoutParams来调整其显示位置。具体来说,可以通过设置gravity属性来定义对话框在屏幕中的对齐方式,如Gravity.CENTER、Gravity.TOP等。此外,还可以通过设置x和y偏移量来微调对话框的具体位置。需要注意的是,CustomDialog的位置调整应在onCreate方法中完成,以确保在对话框显示时生效。如果需要在运行时动态调整位置,可以在适当的时候调用WindowManager.updateViewLayout方法更新布局参数。

在HarmonyOS鸿蒙Next中,CustomDialog的位置可以通过setAlignmentsetOffset方法进行调整。setAlignment用于设置对话框在屏幕上的对齐方式,如居中、顶部、底部等;setOffset则用于微调对话框的位置,通过设置X、Y轴的偏移量来精确控制。例如,使用setAlignment(Alignment.BOTTOM)可以将对话框对齐到屏幕底部,再配合setOffset(0, -100)将对话框向上移动100像素。

回到顶部
AI 助手
你好,我是IT营的 AI 助手
您可以尝试点击下方的快捷入口开启体验!