Commit dd136c49 authored by Ian Hickson's avatar Ian Hickson

Merge pull request #1741 from Hixie/heroes

Unmatched heroes don't need to animate
parents 9ea722d9 5c439f2b
......@@ -70,6 +70,7 @@ class _HeroManifest {
}
abstract class HeroHandle {
bool get alwaysAnimate;
_HeroManifest _takeChild(Rect animationArea);
}
......@@ -78,7 +79,8 @@ class Hero extends StatefulComponent {
Key key,
this.tag,
this.child,
this.turns: 1
this.turns: 1,
this.alwaysAnimate: false
}) : super(key: key) {
assert(tag != null);
}
......@@ -87,6 +89,12 @@ class Hero extends StatefulComponent {
final Widget child;
final int turns;
/// If true, the hero will always animate, even if it has no matching hero to
/// animate to or from. (This only applies if the hero is relevant; if there
/// are multiple heroes with the same tag, only the one whose key matches the
/// "most valuable keys" will be used.)
final bool alwaysAnimate;
static Map<Object, HeroHandle> of(BuildContext context, Set<Key> mostValuableKeys) {
mostValuableKeys ??= new Set<Key>();
assert(!mostValuableKeys.contains(null));
......@@ -143,6 +151,8 @@ class HeroState extends State<Hero> implements HeroHandle {
_HeroMode _mode = _HeroMode.constructing;
Size _size;
bool get alwaysAnimate => config.alwaysAnimate;
_HeroManifest _takeChild(Rect animationArea) {
assert(_mode == _HeroMode.measured || _mode == _HeroMode.taken);
final RenderBox renderObject = context.findRenderObject();
......@@ -235,6 +245,8 @@ class _HeroQuestState implements HeroHandle {
final AnimatedRelativeRectValue currentRect;
final AnimatedValue<double> currentTurns;
bool get alwaysAnimate => true;
bool get taken => _taken;
bool _taken = false;
_HeroManifest _takeChild(Rect animationArea) {
......@@ -319,6 +331,9 @@ class HeroParty {
final List<_HeroQuestState> _newHeroes = <_HeroQuestState>[];
for (_HeroMatch heroPair in heroes.values) {
assert(heroPair.from != null || heroPair.to != null);
if ((heroPair.from == null && !heroPair.to.alwaysAnimate) ||
(heroPair.to == null && !heroPair.from.alwaysAnimate))
continue;
_HeroManifest from = heroPair.from?._takeChild(animationArea);
assert(heroPair.to == null || heroPair.to is HeroState);
_HeroManifest to = heroPair.to?._takeChild(animationArea);
......
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