mirror of
https://github.com/flutter/flutter.git
synced 2025-06-03 00:51:18 +00:00

Each layer is supposed to reexport the parts of the previous layer that are part of its API. - In painting.dart, export from dart:ui all the Canvas-related APIs that make sense to be used at higher levels, e.g. PaintingStyle. - Delete painting/shadows.dart. It was dead code. - In rendering/object.dart, export all of painting.dart. - In widgets/basic.dart, export all of painting.dart and animation.dart. Some classes in animation/ are renamed to make this less disruptive and confusing to the namespace. - Split out Stocks back into an import model rather than a part model, so that it's easier to manage its dependencies on a per-file basis. - Move Ticker to scheduler library. - Remove as many redundant imports as possible now. - Some minor nit picking cleanup in various files.
103 lines
2.4 KiB
Dart
103 lines
2.4 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 'package:flutter/material.dart';
|
|
|
|
const double _kHeight = 150.0;
|
|
const Duration _kEffectDuration = const Duration(seconds: 1);
|
|
|
|
class MimicDemo extends StatefulComponent {
|
|
_MimicDemoState createState() => new _MimicDemoState();
|
|
}
|
|
|
|
class _MimicDemoState extends State<MimicDemo> {
|
|
GlobalKey<MimicableState> _orange = new GlobalKey<MimicableState>();
|
|
GlobalKey _targetContainer = new GlobalKey();
|
|
|
|
bool _slotForOrangeOnTop = false;
|
|
bool _orangeOnTop = false;
|
|
|
|
void _handleTap() {
|
|
if (_slotForOrangeOnTop)
|
|
return;
|
|
setState(() {
|
|
_slotForOrangeOnTop = true;
|
|
});
|
|
MimicOverlayEntry entry = _orange.currentState.liftToOverlay();
|
|
entry.animateTo(targetKey: _targetContainer, duration: _kEffectDuration, curve: Curves.ease).then((_) {
|
|
setState(() {
|
|
_orangeOnTop = true;
|
|
});
|
|
entry.dispose();
|
|
});
|
|
}
|
|
|
|
void _reset() {
|
|
setState(() {
|
|
_slotForOrangeOnTop = false;
|
|
_orangeOnTop = false;
|
|
});
|
|
}
|
|
|
|
Widget _buildOrange() {
|
|
return new Mimicable(
|
|
key: _orange,
|
|
child: new Container(
|
|
height: _kHeight,
|
|
decoration: new BoxDecoration(
|
|
backgroundColor: Colors.deepOrange[500]
|
|
)
|
|
)
|
|
);
|
|
}
|
|
|
|
Widget build(BuildContext context) {
|
|
List<Widget> children = <Widget>[
|
|
new Container(
|
|
height: _kHeight,
|
|
decoration: new BoxDecoration(
|
|
backgroundColor: Colors.amber[500]
|
|
)
|
|
),
|
|
new AnimatedContainer(
|
|
key: _targetContainer,
|
|
height: _slotForOrangeOnTop ? _kHeight : 0.0,
|
|
duration: _kEffectDuration,
|
|
curve: Curves.ease,
|
|
child: _orangeOnTop ? _buildOrange() : null
|
|
),
|
|
new Container(
|
|
height: _kHeight,
|
|
decoration: new BoxDecoration(
|
|
backgroundColor: Colors.green[500]
|
|
)
|
|
),
|
|
new Container(
|
|
height: _kHeight,
|
|
decoration: new BoxDecoration(
|
|
backgroundColor: Colors.blue[500]
|
|
)
|
|
),
|
|
];
|
|
|
|
if (!_orangeOnTop)
|
|
children.add(_buildOrange());
|
|
|
|
return new GestureDetector(
|
|
onTap: _handleTap,
|
|
onLongPress: _reset,
|
|
child: new Block(children: children)
|
|
);
|
|
}
|
|
}
|
|
|
|
void main() {
|
|
runApp(new MaterialApp(
|
|
title: 'Mimic Demo',
|
|
routes: {
|
|
'/': (_) => new MimicDemo()
|
|
}
|
|
));
|
|
}
|