import 'package:flutter/material.dart'; import 'package:flutter_redux/flutter_redux.dart'; import '../store/game_state.dart'; import '../utils/screen.dart'; /// 游戏格子背景 class GameBg extends StatefulWidget { @override State createState() => _GameBgState(); } class _GameBgState extends State { @override Widget build(BuildContext context) { return StoreConnector( converter: (store) => GameBgProps( borderWidth: Screen.getBorderWidth(store.state.mode), blockWidth: Screen.getBlockWidth(store.state.mode), mode: store.state.mode, ), builder: (context, vm) { var width = Screen.stageWidth; return Center( child: Container( width: width, padding: EdgeInsets.fromLTRB(vm.borderWidth, vm.borderWidth, 0, 0), decoration: BoxDecoration( color: const Color(0xffbbada0), border: Border.all(color: Colors.transparent, width: 0), borderRadius: BorderRadius.circular(5), ), child: getGrid(vm), ), ); }, ); } getGrid(GameBgProps props) { var rows = []; for (var i = 0; i < props.mode; i++) { var columns = []; for (var j = 0; j < props.mode; j++) { columns.add(Container( width: props.blockWidth, height: props.blockWidth, decoration: BoxDecoration( color: Color.fromRGBO(238, 228, 218, 0.35), border: Border.all(color: Colors.transparent, width: 0), borderRadius: BorderRadius.circular(5), ), margin: EdgeInsets.fromLTRB(0, 0, props.borderWidth, props.borderWidth), )); } rows.add(Row( textDirection: TextDirection.ltr, crossAxisAlignment: CrossAxisAlignment.center, children: columns, )); } return Column( children: rows, crossAxisAlignment: CrossAxisAlignment.center, ); } } class GameBgProps { double borderWidth; //边框大小 double blockWidth; //块大小 int mode; //游戏模式,3*3 4*4 6*6 GameBgProps({required this.borderWidth, required this.blockWidth, required this.mode}); }