Unverified Commit 4a32e524 authored by nt4f04uNd's avatar nt4f04uNd Committed by GitHub

SpringDescription parameter for the AnimationController fling method (#65057)

parent 3302a12b
...@@ -68,3 +68,4 @@ meritozh <ah841814092@gmail.com> ...@@ -68,3 +68,4 @@ meritozh <ah841814092@gmail.com>
Terrence Addison Tandijono(flotilla) <terrenceaddison32@gmail.com> Terrence Addison Tandijono(flotilla) <terrenceaddison32@gmail.com>
YeungKC <flutter@yeungkc.com> YeungKC <flutter@yeungkc.com>
Nobuhiro Tabuki <japanese.around30@gmail.com> Nobuhiro Tabuki <japanese.around30@gmail.com>
nt4f04uNd <nt4f04und@gmail.com>
...@@ -645,18 +645,27 @@ class AnimationController extends Animation<double> ...@@ -645,18 +645,27 @@ class AnimationController extends Animation<double>
_checkStatusChanged(); _checkStatusChanged();
} }
/// Drives the animation with a critically damped spring (within [lowerBound] /// Drives the animation with a spring (within [lowerBound] and [upperBound])
/// and [upperBound]) and initial velocity. /// and initial velocity.
/// ///
/// If velocity is positive, the animation will complete, otherwise it will /// If velocity is positive, the animation will complete, otherwise it will
/// dismiss. /// dismiss.
/// ///
/// The [springDescription] parameter can be used to specify a custom [SpringType.criticallyDamped]
/// or [SpringType.overDamped] spring to drive the animation with. Defaults to null, which uses a
/// [SpringType.criticallyDamped] spring. See [SpringDescription.withDampingRatio] for how
/// to create a suitable [SpringDescription].
///
/// The resulting spring simulation cannot be of type [SpringType.underDamped],
/// as this can lead to unexpected look of the produced animation.
///
/// Returns a [TickerFuture] that completes when the animation is complete. /// Returns a [TickerFuture] that completes when the animation is complete.
/// ///
/// The most recently returned [TickerFuture], if any, is marked as having been /// The most recently returned [TickerFuture], if any, is marked as having been
/// canceled, meaning the future never completes and its [TickerFuture.orCancel] /// canceled, meaning the future never completes and its [TickerFuture.orCancel]
/// derivative future completes with a [TickerCanceled] error. /// derivative future completes with a [TickerCanceled] error.
TickerFuture fling({ double velocity = 1.0, AnimationBehavior? animationBehavior }) { TickerFuture fling({ double velocity = 1.0, SpringDescription? springDescription, AnimationBehavior? animationBehavior }) {
springDescription ??= _kFlingSpringDescription;
_direction = velocity < 0.0 ? _AnimationDirection.reverse : _AnimationDirection.forward; _direction = velocity < 0.0 ? _AnimationDirection.reverse : _AnimationDirection.forward;
final double target = velocity < 0.0 ? lowerBound - _kFlingTolerance.distance final double target = velocity < 0.0 ? lowerBound - _kFlingTolerance.distance
: upperBound + _kFlingTolerance.distance; : upperBound + _kFlingTolerance.distance;
...@@ -673,8 +682,13 @@ class AnimationController extends Animation<double> ...@@ -673,8 +682,13 @@ class AnimationController extends Animation<double>
break; break;
} }
} }
final Simulation simulation = SpringSimulation(_kFlingSpringDescription, value, target, velocity * scale) final SpringSimulation simulation = SpringSimulation(springDescription, value, target, velocity * scale)
..tolerance = _kFlingTolerance; ..tolerance = _kFlingTolerance;
assert(
simulation.type != SpringType.underDamped,
'The resulting spring simulation is of type SpringType.underDamped.\n'
'This can lead to unexpected look of the animation, please adjust the springDescription parameter'
);
stop(); stop();
return _startSimulation(simulation); return _startSimulation(simulation);
} }
......
...@@ -253,6 +253,29 @@ void main() { ...@@ -253,6 +253,29 @@ void main() {
largeRangeController.stop(); largeRangeController.stop();
}); });
test('Custom springDescription can be applied', () {
final AnimationController controller = AnimationController(
vsync: const TestVSync(),
);
final AnimationController customSpringController = AnimationController(
vsync: const TestVSync(),
);
controller.fling();
// Will produce longer and smoother animation than the default.
customSpringController.fling(
springDescription: SpringDescription.withDampingRatio(
mass: 0.01,
stiffness: 10.0,
ratio: 2.0,
),
);
tick(const Duration(milliseconds: 0));
tick(const Duration(milliseconds: 50));
expect(customSpringController.value < controller.value, true);
});
test('lastElapsedDuration control test', () { test('lastElapsedDuration control test', () {
final AnimationController controller = AnimationController( final AnimationController controller = AnimationController(
duration: const Duration(milliseconds: 100), duration: const Duration(milliseconds: 100),
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment