You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
I want to mimic the edit mode of the iOS Home Screen, where cells wiggle while in edit mode and stop wiggling as soon as the user exits edit mode.
I've tried using .conditionalEffect(.repeat(.wiggle, every: .seconds(0.1)), condition: shouldWiggle), but when the condition becomes false, the effect doesn't stop immediately.
Here's a minimum, reproducible example showcasing the issue:
import Pow
import SwiftUI
structWiggleTester:View{@StateprivatevarshouldWiggle:Bool=falseletcellModels:[String]init(){self.init(
cellModels:(1...10).map(\.description))}init(cellModels:[String]){self.cellModels = cellModels
}varbody:someView{VStack{
grid
.frame(maxWidth:.infinity, maxHeight:.infinity)Button(
action:{ shouldWiggle.toggle()},
label:{Text("Turn Wiggle \(shouldWiggle ?"OFF":"ON")")})}}@ViewBuilderprivatevargrid:someView{letcolumns=[
// Using adaptive columns with a min size to allow the system to fit the appropriate number
// of columns on the screen.
GridItem(.adaptive(minimum:85), spacing:8)]LazyVGrid(columns: columns){ForEach(cellModels, id: \.self){ cellModel incell(model: cellModel).conditionalEffect(.repeat(.wiggle, every:.seconds(0.1)),
condition: shouldWiggle
)}}}privatefunc cell(model:String)->someView{Button(
action:{print("Button tapped \(model)")}, label:{VStack{Text(model).padding().foregroundStyle(Color.primary).background{Color.secondary }.clipShape(Circle())Text(model)}})}}
Screen recording of the problem:
The text was updated successfully, but these errors were encountered:
Hey @davidpasztor, I took a look at the code and the way that the wiggle animation works is that it creates a TimelineView to run a simulation of a 3D transform that moves the icon left and right. I haven't quite deciphered how to achieve the effect you're looking for, especially because it appears that using a conditionalEffect adds even more wiggles like this.
if isConditionalEffect {
wiggleCount +=4}
I may take a look at this in the future but don't have it on my immediate radar. That said, if you would like to contribute I will gladly accept pull requests that create a new parameter that can stop the shaking on demand, I can imagine that it would be useful to others not just yourself!
Sorry I don't have a better answer, I'm still getting familiar with the library well enough to make changes to the physics portion, beyond just maintaining the APIs.
@mergesort thanks for the update, that is valuable information!
I'll see if I can find a way to fix the issue myself, but I'm not that familiar with the physics involved of such effect, so not sure if I'll succeed in a reasonable timeframe.
that create a new parameter that can stop the shaking on demand
The thing that confused me was that the conditionalEffect takes a condition Bool - I'd expect this to take effect immediately, not to let any in-progress effects run their course. Do you think that the docs should be updated to reflect this?
I want to mimic the edit mode of the iOS Home Screen, where cells wiggle while in edit mode and stop wiggling as soon as the user exits edit mode.
I've tried using
.conditionalEffect(.repeat(.wiggle, every: .seconds(0.1)), condition: shouldWiggle)
, but when the condition becomesfalse
, the effect doesn't stop immediately.Here's a minimum, reproducible example showcasing the issue:
Screen recording of the problem:
The text was updated successfully, but these errors were encountered: