animated_widget.0.dart 1.74 KB
Newer Older
1 2 3 4 5 6 7 8
// Copyright 2014 The Flutter 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 'dart:math' as math;

import 'package:flutter/material.dart';

9
/// Flutter code sample for [AnimatedWidget].
10

11
void main() => runApp(const AnimatedWidgetExampleApp());
12

13 14
class AnimatedWidgetExampleApp extends StatelessWidget {
  const AnimatedWidgetExampleApp({super.key});
15 16 17 18

  @override
  Widget build(BuildContext context) {
    return const MaterialApp(
19
      home: AnimatedWidgetExample(),
20 21 22 23 24 25
    );
  }
}

class SpinningContainer extends AnimatedWidget {
  const SpinningContainer({
26
    super.key,
27
    required AnimationController controller,
28
  }) : super(listenable: controller);
29 30 31 32 33 34 35 36 37 38 39 40

  Animation<double> get _progress => listenable as Animation<double>;

  @override
  Widget build(BuildContext context) {
    return Transform.rotate(
      angle: _progress.value * 2.0 * math.pi,
      child: Container(width: 200.0, height: 200.0, color: Colors.green),
    );
  }
}

41 42
class AnimatedWidgetExample extends StatefulWidget {
  const AnimatedWidgetExample({super.key});
43 44

  @override
45
  State<AnimatedWidgetExample> createState() => _AnimatedWidgetExampleState();
46 47
}

48 49
/// [AnimationController]s can be created with `vsync: this` because of
/// [TickerProviderStateMixin].
50
class _AnimatedWidgetExampleState extends State<AnimatedWidgetExample> with TickerProviderStateMixin {
51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66
  late final AnimationController _controller = AnimationController(
    duration: const Duration(seconds: 10),
    vsync: this,
  )..repeat();

  @override
  void dispose() {
    _controller.dispose();
    super.dispose();
  }

  @override
  Widget build(BuildContext context) {
    return SpinningContainer(controller: _controller);
  }
}