Я пытаюсь создать аккордеонный стиль с анимацией, используя SwiftUI.Но анимации не работают должным образом, если я помещаю их в ScrollView. Ниже приведен код, который я пытаюсь разработать.
struct ParentView: View {
@State var isPressed = false
var body: some View {
GeometryReader { geometry in
ScrollView {
Group {
SampleView(index: 1)
SampleView(index: 2)
SampleView(index: 3)
SampleView(index: 4)
}.border(Color.black).frame(maxWidth: .infinity)
}.border(Color.green)
}
}
}
struct SampleView: View {
@State var index: Int
@State var isPressed = false
var body: some View {
Group {
HStack(alignment:.top) {
VStack(alignment: .leading) {
Text("********************")
Text("This View = \(index)")
Text("********************")
}
Spacer()
Button("Press") { self.isPressed.toggle() }
}
if isPressed {
VStack(alignment: .leading) {
Text("********************")
Text("-----> = \(index)")
Text("********************")
}.transition(.slide).animation(.linear).border(Color.red)
}
}
}
}
А ниже приведен скриншот проблемы, с которой я сталкиваюсь.
data:image/s3,"s3://crabby-images/de720/de720e22867f0652ad7da192f58e934180e12bef" alt="enter image description here"
data:image/s3,"s3://crabby-images/4a99b/4a99b0dbacbf658258c3a94376be352fdb0e3894" alt="enter image description here"