Sobes.tech
Back to questions
Middle
214

Расскажите о анимации в Flutter.

Answer from AI

sobes.tech AI

В Flutter анимации делятся на два основных типа: имплицитные и эксплицитные.

  • Имплицитные анимации — это простые анимации, которые автоматически управляют изменениями состояния виджета. Например, AnimatedContainer плавно изменяет свои параметры (цвет, размер) при изменении свойств без необходимости писать контроллеры анимации.

  • Эксплицитные анимации дают полный контроль над процессом анимации. Для них используется AnimationController, который управляет временем и прогрессом анимации. С помощью Tween и Animation можно задавать, как именно изменяются значения во времени.

Пример имплицитной анимации:

AnimatedContainer(
  duration: Duration(seconds: 1),
  width: _selected ? 200 : 100,
  height: _selected ? 200 : 100,
  color: _selected ? Colors.blue : Colors.red,
  child: ...,
)

Пример эксплицитной анимации:

class MyAnimatedWidget extends StatefulWidget {
  @override
  _MyAnimatedWidgetState createState() => _MyAnimatedWidgetState();
}

class _MyAnimatedWidgetState extends State<MyAnimatedWidget> with SingleTickerProviderStateMixin {
  late AnimationController _controller;
  late Animation<double> _animation;

  @override
  void initState() {
    super.initState();
    _controller = AnimationController(vsync: this, duration: Duration(seconds: 2));
    _animation = Tween<double>(begin: 0, end: 300).animate(_controller);
    _controller.forward();
  }

  @override
  Widget build(BuildContext context) {
    return AnimatedBuilder(
      animation: _animation,
      builder: (context, child) {
        return Container(
          width: _animation.value,
          height: _animation.value,
          color: Colors.blue,
        );
      },
    );
  }

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

Таким образом, Flutter предоставляет мощные средства для создания плавных и отзывчивых анимаций, которые улучшают пользовательский опыт.