HarmonyOS 如何制作自定义加载弹窗

写好加载的样式后(比如一个正方形),主要需要让这个正方形无限旋转。如果使用动画好像实现不了,promptAction.openCustomDialog里面也写不了计时器。没办法让正方形无限旋转。

HarmonyOS
2024-09-24 12:07:43
浏览
收藏 0
回答 1
待解决
回答 1
按赞同
/
按时间
FengTianYa

参考示例如下:

import promptAction from '@ohos.promptAction'  
  
@Entry  
@Component  
struct Index {  
  @State message: string = '弹框'  
  @State animate: boolean = false;  
  @State rotateAngle: number = 0  
  
  @Builder customDialogBuilder() {  
    Column() {  
      Text('内容').fontSize(15).margin({ bottom: 50 })  
      Row() {  
        Text('点击旋转')  
          .fontSize(20)  
          .textAlign(TextAlign.Center)  
          .width(100)  
          .height(100)  
          .borderStyle(BorderStyle.Solid)  
          .borderWidth(5)  
          .borderColor(0xAFEEEE)  
          .onClick(() => {  
            this.rotateAngle = 360  
          })  
          .rotate({ angle: this.rotateAngle })  
          .animation({  
            duration: 1200,  
            curve: Curve.Linear,  
            iterations: -1, // 设置-1表示动画无限循环  
          })  
      }  
    }.height(300).padding(5)  
  }  
  
  
  build() {  
    Row() {  
      Column() {  
        Text('点击弹框')  
          .fontSize(50)  
          .fontWeight(FontWeight.Bold)  
          .onClick(() => {  
            promptAction.openCustomDialog({  
              builder: this.customDialogBuilder.bind(this)  
            })  
          })  
      }  
      .width('100%')  
    }  
    .height('100%')  
  }  
}
分享
微博
QQ
微信
回复
2024-09-24 17:58:36
相关问题
自定义弹窗自定义转场动画
1128浏览 • 1回复 待解决
HarmonyOS 自定义弹窗选择
353浏览 • 1回复 待解决
如何自定义弹窗中再次弹窗
2267浏览 • 1回复 待解决
HarmonyOS 全局自定义弹窗demo
286浏览 • 1回复 待解决
HarmonyOS 自定义弹窗的问题
694浏览 • 1回复 待解决
HarmonyOS 自定义弹窗CustomDialog问题
612浏览 • 1回复 待解决
自定义弹窗如何嵌套使用
1676浏览 • 1回复 待解决
HarmonyOS 自定义弹窗遮罩未全屏
665浏览 • 1回复 待解决
如何设置自定义弹窗位置
2068浏览 • 1回复 待解决
HarmonyOS 自定义弹窗 (CustomDialog)问题
396浏览 • 1回复 待解决
使用自定义弹窗实现分享弹窗
566浏览 • 1回复 待解决
自定义弹窗使用相关问题
922浏览 • 1回复 待解决
HarmonyOS 自定义弹窗封装后不显示
337浏览 • 1回复 待解决
如何自定义popup弹窗的布局?
439浏览 • 2回复 待解决
HarmonyOS 自定义弹窗部分问题答疑
311浏览 • 1回复 待解决