refresh期望能够自定义loading动画

refresh点击触发刷新组件期望能够自定义刷新动画,可以使用json文件的lottie动画。

tabbar使用refresh组件实现点击刷新,但是无法自定义动画。

HarmonyOS
2024-06-03 23:48:23
浏览
收藏 0
回答 1
待解决
回答 1
按赞同
/
按时间
bysc111

使用imageAnimator的实现方式来替换lottie即可。

示例代码:

// xxx.ets 
@Entry 
@Component 
struct RefreshExample { 
  @State isRefreshing: boolean = false 
  @State counter: number = 0 
  @State durationTime: number = 50 //每个数字动画时长,50m 
  @State aniState: AnimationStatus = AnimationStatus.Initial 
 
  @Builder 
  RefreshAnimation() { 
    Column() { 
      ImageAnimator() 
        .images([{ 
          src: 'image/dl_sdk_anim_000.png', 
          duration: this.durationTime 
        }]) 
        .state(this.aniState) 
        .reverse(false) 
        .fillMode(FillMode.Both) 
        .iterations(-1) 
        .width(40) 
        .height(40) 
        .margin({ top: 10 }) 
        .onStart(() => { 
          console.info('LoadingDialog Start') 
        }) 
        .onPause(() => { 
          console.info('LoadingDialog Pause') 
        }) 
        .onRepeat(() => { 
          console.info('LoadingDialog Repeat') 
        }) 
        .onCancel(() => { 
          console.info('LoadingDialog Cancel') 
        }) 
        .onFinish(() => { 
          console.info('LoadingDialog Finish') 
        }) 
    } 
  } 
 
  build() { 
    Column() { 
      Refresh({ refreshing: $$this.isRefreshing, offset: 120, friction: 100, builder: this.RefreshAnimation }) { 
        Text('Pull Down and refresh: ' + this.counter) 
          .fontSize(30) 
          .margin(10) 
      } 
      .onStateChange((refreshStatus: RefreshStatus) => { 
        console.info('Refresh onStatueChange state is ' + refreshStatus) 
      }) 
      .onRefreshing(() => { 
        this.aniState = AnimationStatus.Running 
        setTimeout(() => { 
          this.counter++ 
          this.isRefreshing = false 
          this.aniState = AnimationStatus.Stopped 
        }, 1000) 
        console.log('onRefreshing test') 
      }) 
    } 
  } 
}
分享
微博
QQ
微信
回复
2024-06-04 22:40:30
相关问题
自定义弹窗自定义转场动画
448浏览 • 1回复 待解决
如何实现自定义应用入场动画
409浏览 • 1回复 待解决
是否能够自定义router跳转的url
542浏览 • 1回复 待解决
弹窗打开、关闭动画是否支持自定义
861浏览 • 1回复 待解决
hvigor自定义扩展demo
394浏览 • 1回复 待解决
如何自定义模拟Tabs组件
429浏览 • 1回复 待解决
Code Linter自定义代码规范
532浏览 • 1回复 待解决
ArkTs如何自定义容器组件?
1784浏览 • 1回复 待解决
自定义弹窗如何嵌套使用
526浏览 • 1回复 待解决
是否支持自定义装饰器
958浏览 • 1回复 待解决
自定义组件嵌套子组件
8059浏览 • 3回复 待解决
自定义弹窗使用相关问题
422浏览 • 1回复 待解决
如何自定义组件原型菜单
471浏览 • 1回复 待解决
如何访问自定义文件?
373浏览 • 1回复 待解决
如何自定义Component 属性
13546浏览 • 3回复 待解决