Commit e459e712 authored by Adam Barth's avatar Adam Barth

Port the remainder of the framework to AnimationController

There should be no more uses of Performance or AnimatedValue in the framework
or the examples.
parent aabd1ce4
...@@ -18,7 +18,7 @@ class PageSelectorDemo extends StatelessComponent { ...@@ -18,7 +18,7 @@ class PageSelectorDemo extends StatelessComponent {
builder: (BuildContext context, Widget child) { builder: (BuildContext context, Widget child) {
Color background = selection.value == iconName ? _selectedColor.end : _selectedColor.begin; Color background = selection.value == iconName ? _selectedColor.end : _selectedColor.begin;
if (selection.valueIsChanging) { if (selection.valueIsChanging) {
// Then the selection's performance is animating from previousValue to value. // Then the selection's animation is animating from previousValue to value.
if (selection.value == iconName) if (selection.value == iconName)
background = _selectedColor.evaluate(animation); background = _selectedColor.evaluate(animation);
else if (selection.previousValue == iconName) else if (selection.previousValue == iconName)
......
...@@ -11,7 +11,6 @@ import 'tween.dart'; ...@@ -11,7 +11,6 @@ import 'tween.dart';
class AlwaysCompleteAnimation extends Animated<double> { class AlwaysCompleteAnimation extends Animated<double> {
const AlwaysCompleteAnimation(); const AlwaysCompleteAnimation();
// this performance never changes state
void addListener(VoidCallback listener) { } void addListener(VoidCallback listener) { }
void removeListener(VoidCallback listener) { } void removeListener(VoidCallback listener) { }
void addStatusListener(PerformanceStatusListener listener) { } void addStatusListener(PerformanceStatusListener listener) { }
...@@ -26,7 +25,6 @@ const AlwaysCompleteAnimation kAlwaysCompleteAnimation = const AlwaysCompleteAni ...@@ -26,7 +25,6 @@ const AlwaysCompleteAnimation kAlwaysCompleteAnimation = const AlwaysCompleteAni
class AlwaysDismissedAnimation extends Animated<double> { class AlwaysDismissedAnimation extends Animated<double> {
const AlwaysDismissedAnimation(); const AlwaysDismissedAnimation();
// this performance never changes state
void addListener(VoidCallback listener) { } void addListener(VoidCallback listener) { }
void removeListener(VoidCallback listener) { } void removeListener(VoidCallback listener) { }
void addStatusListener(PerformanceStatusListener listener) { } void addStatusListener(PerformanceStatusListener listener) { }
......
...@@ -5,31 +5,32 @@ ...@@ -5,31 +5,32 @@
import 'dart:async'; import 'dart:async';
import 'package:newton/newton.dart'; import 'package:newton/newton.dart';
import 'animated_value.dart';
import 'curves.dart'; import 'curves.dart';
import 'ticker.dart'; import 'ticker.dart';
/// A simulation that varies from [begin] to [end] over [duration] using [curve]. /// A simulation that varies from begin to end over duration using curve.
///
/// This class is an adaptor between the Simulation interface and the
/// AnimatedValue interface.
class _TweenSimulation extends Simulation { class _TweenSimulation extends Simulation {
_TweenSimulation(double begin, double end, Duration duration, Curve curve) _TweenSimulation(this._begin, this._end, Duration duration, this._curve)
: _durationInSeconds = duration.inMicroseconds / Duration.MICROSECONDS_PER_SECOND, : _durationInSeconds = duration.inMicroseconds / Duration.MICROSECONDS_PER_SECOND {
_tween = new AnimatedValue<double>(begin, end: end, curve: curve) {
assert(_durationInSeconds > 0.0); assert(_durationInSeconds > 0.0);
assert(begin != null); assert(_begin != null);
assert(end != null); assert(_end != null);
} }
final double _durationInSeconds; final double _durationInSeconds;
final AnimatedValue<double> _tween; final double _begin;
final double _end;
final Curve _curve;
double x(double timeInSeconds) { double x(double timeInSeconds) {
assert(timeInSeconds >= 0.0); assert(timeInSeconds >= 0.0);
final double t = (timeInSeconds / _durationInSeconds).clamp(0.0, 1.0); double t = (timeInSeconds / _durationInSeconds).clamp(0.0, 1.0);
_tween.setProgress(t, AnimationDirection.forward); if (t == 0.0)
return _tween.value; return _begin;
else if (t == 1.0)
return _end;
else
return _begin + (_end - _begin) * _curve.transform(t);
} }
double dx(double timeInSeconds) => 1.0; double dx(double timeInSeconds) => 1.0;
......
...@@ -100,6 +100,10 @@ abstract class Evaluatable<T> { ...@@ -100,6 +100,10 @@ abstract class Evaluatable<T> {
Animated<T> animate(Animated<double> parent) { Animated<T> animate(Animated<double> parent) {
return new _AnimatedEvaluation<T>(parent, this); return new _AnimatedEvaluation<T>(parent, this);
} }
Evaluatable<T> chain(Evaluatable<double> parent) {
return new _ChainedEvaluation<T>(parent, this);
}
} }
class _AnimatedEvaluation<T> extends Animated<T> with ProxyAnimatedMixin { class _AnimatedEvaluation<T> extends Animated<T> with ProxyAnimatedMixin {
...@@ -113,6 +117,31 @@ class _AnimatedEvaluation<T> extends Animated<T> with ProxyAnimatedMixin { ...@@ -113,6 +117,31 @@ class _AnimatedEvaluation<T> extends Animated<T> with ProxyAnimatedMixin {
T get value => _evaluatable.evaluate(parent); T get value => _evaluatable.evaluate(parent);
} }
class AlwaysStoppedAnimation extends Animated<double> {
const AlwaysStoppedAnimation(this.value);
final double value;
void addListener(VoidCallback listener) { }
void removeListener(VoidCallback listener) { }
void addStatusListener(PerformanceStatusListener listener) { }
void removeStatusListener(PerformanceStatusListener listener) { }
PerformanceStatus get status => PerformanceStatus.forward;
AnimationDirection get direction => AnimationDirection.forward;
}
class _ChainedEvaluation<T> extends Evaluatable<T> {
_ChainedEvaluation(this._parent, this._evaluatable);
final Evaluatable<double> _parent;
final Evaluatable<T> _evaluatable;
T evaluate(Animated<double> animation) {
double value = _parent.evaluate(animation);
return _evaluatable.evaluate(new AlwaysStoppedAnimation(value));
}
}
class AnimationController extends Animated<double> class AnimationController extends Animated<double>
with EagerListenerMixin, LocalPerformanceListenersMixin, LocalPerformanceStatusListenersMixin { with EagerListenerMixin, LocalPerformanceListenersMixin, LocalPerformanceStatusListenersMixin {
AnimationController({ this.duration, double value, this.debugLabel }) { AnimationController({ this.duration, double value, this.debugLabel }) {
......
...@@ -854,9 +854,8 @@ abstract class RenderBoxContainerDefaultsMixin<ChildType extends RenderBox, Pare ...@@ -854,9 +854,8 @@ abstract class RenderBoxContainerDefaultsMixin<ChildType extends RenderBox, Pare
} }
} }
class AnimatedFractionalOffsetValue extends AnimatedValue<FractionalOffset> { class FractionalOffsetTween extends Tween<FractionalOffset> {
AnimatedFractionalOffsetValue(FractionalOffset begin, { FractionalOffset end, Curve curve, Curve reverseCurve }) FractionalOffsetTween({ FractionalOffset begin, FractionalOffset end }) : super(begin: begin, end: end);
: super(begin, end: end, curve: curve, reverseCurve: reverseCurve);
FractionalOffset lerp(double t) => FractionalOffset.lerp(begin, end, t); FractionalOffset lerp(double t) => FractionalOffset.lerp(begin, end, t);
} }
...@@ -30,32 +30,41 @@ class SmoothlyResizingOverflowBox extends StatefulComponent { ...@@ -30,32 +30,41 @@ class SmoothlyResizingOverflowBox extends StatefulComponent {
} }
class _SmoothlyResizingOverflowBoxState extends State<SmoothlyResizingOverflowBox> { class _SmoothlyResizingOverflowBoxState extends State<SmoothlyResizingOverflowBox> {
ValuePerformance<Size> _size; SizeTween _sizeTween;
CurveTween _curveTween;
Animated<Size> _size;
AnimationController _sizeController;
void initState() { void initState() {
super.initState(); super.initState();
_size = new ValuePerformance( _sizeController = new AnimationController(duration: config.duration);
variable: new AnimatedSizeValue(config.size, curve: config.curve), _sizeTween = new SizeTween(begin: config.size);
duration: config.duration _curveTween = new CurveTween(curve: config.curve);
)..addListener(() { _size = _sizeTween.chain(_curveTween).animate(_sizeController)
..addListener(() {
setState(() {}); setState(() {});
}); });
} }
void didUpdateConfig(SmoothlyResizingOverflowBox oldConfig) { void didUpdateConfig(SmoothlyResizingOverflowBox oldConfig) {
_size.duration = config.duration; bool needsAnimation = false;
_size.variable.curve = config.curve;
if (config.size != oldConfig.size) { if (config.size != oldConfig.size) {
AnimatedSizeValue variable = _size.variable; _sizeTween
variable.begin = variable.value; ..begin = _size.value
variable.end = config.size; ..end = config.size;
_size.progress = 0.0; needsAnimation = true;
_size.play(); }
_sizeController.duration = config.duration;
_curveTween.curve = config.curve;
if (needsAnimation) {
_sizeController
..value = 0.0
..forward();
} }
} }
void dispose() { void dispose() {
_size.stop(); _sizeController.stop();
super.dispose(); super.dispose();
} }
......
...@@ -193,24 +193,6 @@ class RotationTransition extends AnimatedComponent { ...@@ -193,24 +193,6 @@ class RotationTransition extends AnimatedComponent {
} }
} }
class OldFadeTransition extends TransitionWithChild {
OldFadeTransition({
Key key,
this.opacity,
PerformanceView performance,
Widget child
}) : super(key: key,
performance: performance,
child: child);
final AnimatedValue<double> opacity;
Widget buildWithChild(BuildContext context, Widget child) {
performance.updateVariable(opacity);
return new Opacity(opacity: opacity.value, child: child);
}
}
class FadeTransition extends AnimatedComponent { class FadeTransition extends AnimatedComponent {
FadeTransition({ FadeTransition({
Key key, Key key,
...@@ -226,20 +208,17 @@ class FadeTransition extends AnimatedComponent { ...@@ -226,20 +208,17 @@ class FadeTransition extends AnimatedComponent {
} }
} }
class ColorTransition extends TransitionWithChild { class ColorTransition extends AnimatedComponent {
ColorTransition({ ColorTransition({
Key key, Key key,
this.color, Animated<Color> color,
PerformanceView performance, this.child
Widget child }) : color = color, super(key: key, animation: color);
}) : super(key: key,
performance: performance,
child: child);
final AnimatedColorValue color; final Animated<Color> color;
final Widget child;
Widget buildWithChild(BuildContext context, Widget child) { Widget build(BuildContext context) {
performance.updateVariable(color);
return new DecoratedBox( return new DecoratedBox(
decoration: new BoxDecoration(backgroundColor: color.value), decoration: new BoxDecoration(backgroundColor: color.value),
child: child child: child
......
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