Есть ли способы анимировать кнопку во Flutter с эффектом дайса?

Да, в Flutter существует несколько способов анимирования кнопки со эффектом дайса. Один из способов - использование анимации контейнера и таймера.

Во-первых, вам понадобится добавить зависимость "flutter_bloc" в файле pubspec.yaml вашего проекта:

dependencies:
  flutter_bloc: ^7.0.0

Во-вторых, вы должны создать класс анимации, который будет управлять анимацией кнопки. В этом классе вы можете использовать контроллер анимации и таймер, чтобы выполнять анимацию с определенными интервалами.

import 'package:flutter/material.dart';
import 'dart:async';

class DiceAnimation extends StatefulWidget {
  @override
  _DiceAnimationState createState() => _DiceAnimationState();
}

class _DiceAnimationState extends State<DiceAnimation>
    with TickerProviderStateMixin {
  AnimationController _animationController;
  Timer _timer;

  @override
  void initState() {
    super.initState();

    // Создание контроллера анимации
    _animationController = AnimationController(
      duration: const Duration(milliseconds: 100),
      vsync: this,
    );

    // Настройка таймера
    _timer = Timer.periodic(const Duration(milliseconds: 500), (_) {
      _animationController.forward(from: 0.0);
    });
  }

  @override
  void dispose() {
    // Очистка ресурсов при уничтожении виджета
    _animationController.dispose();
    _timer.cancel();
    super.dispose();
  }

  @override
  Widget build(BuildContext context) {
    return AnimatedBuilder(
      animation: _animationController,
      builder: (BuildContext context, Widget child) {
        return FlatButton(
          onPressed: () {
            // Ваш код обработки нажатия кнопки
          },
          child: Transform.rotate(
            angle: _animationController.value * 2 * 3.141592,
            child: Icon(Icons.casino),
          ),
        );
      },
    );
  }
}

Теперь вы можете использовать этот класс в вашем виджете для анимации кнопки:

import 'package:flutter/material.dart';

class MyButtonPage extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('Button Animation'),
      ),
      body: Center(
        child: Container(
          child: DiceAnimation(),
        ),
      ),
    );
  }
}

В данном примере используется класс FlatButton для отображения кнопки и класс Icon для отображения символа кости. Внутри метода build класса _DiceAnimationState используется Transform.rotate для применения анимации вращения на кнопку.