XCode (Lỗi?) (SwiftUI): Thay vì Quy mô và Thay đổi Độ mờ ở đâu, Chế độ xem của tôi đến từ mép màn hình
Tôi đang cố gắng tạo một vòng tròn trên màn hình của mình với hai vòng tròn đằng sau nó trong ZStack để dễ dàng ra vào bằng ScaleEffect () và thay đổi độ mờ. Tôi đã thực hiện điều này trong một tệp SwiftUI riêng biệt, nơi dường như không có vấn đề gì, nhưng khi tôi đặt nó vào ContentView (), lỗi kỳ lạ này dường như xảy ra.
Vui lòng bỏ qua các vòng tròn trong nền, đó chỉ là chế độ xem nền của tôi. Nhưng hãy xem hai vòng tròn có sắc thái hơi khác nhau của màu xanh lam? Họ tiếp tục vào và ra khỏi màn hình, đến sau biểu tượng "dấu cộng" màu xanh đậm rồi lại rời đi. Trong khi đó, tôi chỉ muốn họ đứng sau vòng tròn "dấu cộng".
nhập mô tả hình ảnh ở đây
nhập mô tả hình ảnh ở đây
Nhập mô tả hình ảnh ở đây Đây có phải là do một số loại lỗi XCode? Hay tôi đã viết sai điều gì đó trong mã của mình? Tôi thực sự sẽ đánh giá cao nó nếu ai đó có thể làm rõ :)
Đây là mã của tôi. Tôi đã tạo một var buttonIsAnimating riêng tư @State và mặc định nó thành false, đồng thời nói rằng khi nút này xuất hiện, các vòng kết nối sẽ bắt đầu hoạt ảnh. Có gì đó sai với mã không?
ZStack {
Group {
Circle()
.fill(Color("Background2").opacity(self.buttonIsAnimating ? 0.6 : 0))
.frame(width: 75, height: 75, alignment: .center)
.scaleEffect(self.buttonIsAnimating ? 1 : 0)
Circle()
.fill(Color("Background3").opacity(self.buttonIsAnimating ? 0.7 : 0))
.frame(width: 89, height: 89, alignment: .center)
.scaleEffect(self.buttonIsAnimating ? 1 : 0)
}
.animation(Animation.easeInOut(duration: 2).repeatForever(autoreverses: true))
Button(action: {
self.showingAddANewToDoView.toggle()
}) {
Image(systemName: "plus.circle.fill")
.resizable()
.scaledToFit()
.background(Circle().fill(Color("Background")))
.foregroundColor(Color("Background4"))
.frame(width: 60, height: 60)
.padding(5)
}//: Button
.onAppear {
self.buttonIsAnimating.toggle()
}
}
Trả lời
Thử với hoạt ảnh liên kết đến trạng thái, như
Group {
Circle()
.fill(Color("Background2").opacity(self.buttonIsAnimating ? 0.6 : 0))
.frame(width: 75, height: 75, alignment: .center)
.scaleEffect(self.buttonIsAnimating ? 1 : 0)
Circle()
.fill(Color("Background3").opacity(self.buttonIsAnimating ? 0.7 : 0))
.frame(width: 89, height: 89, alignment: .center)
.scaleEffect(self.buttonIsAnimating ? 1 : 0)
}
.animation(Animation.easeInOut(duration: 2).repeatForever(autoreverses: true),
value: self.buttonIsAnimating)