mirror of
https://github.com/flutter/flutter.git
synced 2026-02-20 02:29:02 +08:00
This is a prerequisite to dropping 'display:none'. Included in this CL is making AnimatedValue able to animate more than one field. R=abarth@chromium.org Review URL: https://codereview.chromium.org/1126333006
41 lines
1.1 KiB
Dart
41 lines
1.1 KiB
Dart
// Copyright 2015 The Chromium Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
import '../animation/animated_value.dart';
|
|
import '../fn.dart';
|
|
import 'dart:mirrors';
|
|
|
|
abstract class AnimatedComponent extends Component {
|
|
AnimatedComponent({ Object key }) : super(key: key, stateful: true);
|
|
|
|
var _debugAnimatedFields = new Set<Symbol>();
|
|
bool _debugIsNotYetAnimated(Symbol s) {
|
|
return _debugAnimatedFields.add(s);
|
|
}
|
|
|
|
animateField(AnimatedValue value, Symbol symbol) {
|
|
// TODO(rafaelw): Assert symbol is present on |this|, is private and
|
|
// is over the same parameterized type as the animated value.
|
|
var mirror = reflect(this);
|
|
var subscription;
|
|
|
|
assert(_debugIsNotYetAnimated(symbol));
|
|
mirror.setField(symbol, value.value);
|
|
|
|
onDidMount(() {
|
|
subscription = value.onValueChanged.listen((_) {
|
|
mirror.setField(symbol, value.value);
|
|
scheduleBuild();
|
|
});
|
|
});
|
|
|
|
onDidUnmount(() {
|
|
if (subscription != null) {
|
|
subscription.cancel();
|
|
subscription = null;
|
|
}
|
|
});
|
|
}
|
|
}
|