![](/img/trans.png)
[英]How to animate the transition between light and dark mode using SwiftUI?
[英]SwiftUI: how to animate transition between two Images using a delay?
我有两个图像ImageA
和ImageB
,我的目标是通过以下方式为它们之间的过渡设置动画:
ImageA
已加载ImageA
转换为ImageB
,持续时间为 1.5 秒使用常规 Swift,它将使用带有动画持续时间和暂停的UIView.animate
闭包。
这是我对 SwiftUI 的尝试,它没有显示平滑的过渡,而是硬图像更改:
VStack(alignment: .leading, spacing: 0) {
Image(images.randomElement()!)
.resizable()
.scaledToFill()
.onAppear {
DispatchQueue.main.asyncAfter(deadline: .now() + 1.0) {
withAnimation() { //added
self.shouldTransition.toggle()
}
}
if shouldTransition {
Image(images.randomElement()!)
.resizable()
.animation(.easeInOut(duration: 1.5))
.scaledToFill()
}
}
我的实现中缺少什么来为图像过渡设置动画?
编辑:整个代码库可以在这里找到: TestWidget Github
您必须在观察到的变化周围添加withAnimation() { ... }
包装器,您希望对其进行动画处理。
将您的代码更改为
DispatchQueue.main.asyncAfter(deadline: .now() + 1.0) {
withAnimation(){
self.shouldTransition.toggle()
}
}
您没有指定您想要哪种过渡,默认情况下 SwiftUI 使用不透明度...
尝试以下
VStack(alignment: .leading, spacing: 0) {
if !shouldTransition {
Image(images.randomElement()!)
.resizable()
.scaledToFill()
.onAppear {
DispatchQueue.main.asyncAfter(deadline: .now() + 1.0) {
self.shouldTransition.toggle()
}
}
//.transition(.move(edge: .top)) // uncomment to modify transition
}
if shouldTransition {
Image(images.randomElement()!)
.resizable()
.scaledToFill()
//.transition(.move(edge: .top)) // uncomment to modify transition
}
}.animation(.easeInOut(duration: 1.5), value: shouldTransition)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.