Skip to content
Snippets Groups Projects
Select Git revision
  • 991eebb496be2011574d1a9a3733cde9bf703d60
  • master default protected
  • 61-upgrade-framework-and-dependencies
  • 42-improve-app-metadata
  • 17-improve-and-complete-offline-words-list-and-tips
  • 6-allow-translate-application
  • 9-improve-documentation
  • Release_1.10.0_44 protected
  • Release_1.9.2_43 protected
  • Release_1.9.1_42 protected
  • Release_1.9.0_41 protected
  • Release_1.8.0_40 protected
  • Release_1.7.0_39 protected
  • Release_1.6.0_38 protected
  • Release_1.5.2_37 protected
  • Release_1.5.1_36 protected
  • Release_1.5.0_35 protected
  • Release_1.4.1_34 protected
  • Release_1.4.0_33 protected
  • Release_1.3.2_32 protected
  • Release_1.3.1_31 protected
  • Release_1.3.0_30 protected
  • Release_1.2.18_29 protected
  • Release_1.2.17_28 protected
  • Release_1.2.16_27 protected
  • Release_1.2.15_26 protected
  • Release_1.2.14_25 protected
27 results

game.dart

Blame
  • game.dart 4.65 KiB
    import 'package:flutter/material.dart';
    import 'package:provider/provider.dart';
    import '../provider/data.dart';
    import '../utils/constants.dart';
    import '../utils/random_pick.dart';
    import '../widgets/letters.dart';
    
    class Game extends StatelessWidget {
      static const String id = 'game';
    
      Future<void> pickWord(BuildContext context, Data myProvider) async {
        myProvider.searching = true;
        RandomPick randompick;
        int attempts = 0;
        do {
          randompick = RandomPick(myProvider.levelPref);
          await randompick.init();
          if (randompick.word != null) {
            myProvider.updateSecretWord = randompick.word;
            myProvider.resetSuccessAndErrors();
            myProvider.resetUsedLetters();
            if (myProvider.levelPref == defaultLevel) {
              myProvider.updateClue = randompick.clue;
            }
            myProvider.searching = false;
            break;
          }
          attempts++;
        } while (attempts < 3);
      }
    
      @override
      Widget build(BuildContext context) {
        Orientation orientation = MediaQuery.of(context).orientation;
        Data _myProvider = Provider.of<Data>(context);
    
        return Scaffold(
          backgroundColor: Color(board),
          floatingActionButton: _myProvider.levelPref == defaultLevel
              ? FloatingActionButton(
                  foregroundColor: Colors.white,
                  backgroundColor: Colors.transparent,
                  elevation: 0.0,
                  onPressed: () {
                    showDialog(
                      context: context,
                      builder: (context) {
                        return AlertDialog(
                          title: Text('Indice'),
                          content: Text(_myProvider.clue),
                          actions: <Widget>[
                            FlatButton(
                              child: Text('Revenir au jeu'),
                              onPressed: () => Navigator.of(context).pop(),
                            )
                          ],
                        );
                      },
                    );
                  },
                  child: Icon(Icons.help_outline),
                )
              : null,
          floatingActionButtonLocation: orientation == Orientation.portrait
              ? FloatingActionButtonLocation.endTop
              : FloatingActionButtonLocation.centerTop,
          body: orientation == Orientation.portrait
              ? Column(
                  mainAxisAlignment: MainAxisAlignment.spaceBetween,
                  children: [
                    Flexible(
                      child: Padding(
                        padding: EdgeInsets.only(top: 60.0, left: 30.0, right: 30.0, bottom: 10.0),
                        child: const ImgGallow(),
                      ),
                    ),
                    Padding(
                      padding: const EdgeInsets.symmetric(horizontal: 30.0),
                      child: const HiddenWord(),
                    ),
                    const LetterButtons(),
                  ],
                )
              : Row(
                  children: [
                    Expanded(
                      flex: 2,
                      child: Column(
                        children: [
                          Expanded(
                            child: Padding(
                              padding: const EdgeInsets.only(top: 40.0),
                              child: ImgGallow(),
                            ),
                          ),
                          Padding(
                            padding: const EdgeInsets.symmetric(horizontal: 10.0, vertical: 20.0),
                            child: const HiddenWord(),
                          ),
                        ],
                      ),
                    ),
                    Expanded(child: LetterButtons()),
                  ],
                ),
        );
      }
    }
    
    class ImgGallow extends StatelessWidget {
      const ImgGallow({Key key}) : super(key: key);
      @override
      Widget build(BuildContext context) {
        Data _myProvider = Provider.of<Data>(context);
        return Stack(
          children: [
            for (int error = 0; error < 7; error++)
              AnimatedOpacity(
                opacity: _myProvider.errors >= error ? 1.0 : 0.0,
                duration: Duration(milliseconds: _myProvider.errors >= error ? 800 : 0),
                child: Image.asset('assets/images/img${error + 1}.png'),
              )
          ],
        );
      }
    }
    
    class HiddenWord extends StatelessWidget {
      const HiddenWord({Key key}) : super(key: key);
      @override
      Widget build(BuildContext context) {
        Data _myProvider = Provider.of<Data>(context);
        return FittedBox(
          child: Text(
            (_myProvider.hiddenWord.isEmpty || _myProvider.hiddenWord == null)
                ? 'UNEXPECTED ERROR'
                : _myProvider.hiddenWord,
            style: TextStyle(
              fontFamily: 'Tiza',
              color: Colors.white,
              fontSize: 34.0,
              letterSpacing: 10.0,
            ),
          ),
        );
      }
    }