123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475 |
- 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<StatefulWidget> createState() => _GameBgState();
- }
- class _GameBgState extends State<StatefulWidget> {
- @override
- Widget build(BuildContext context) {
- return StoreConnector<GameState, GameBgProps>(
- 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 = <Widget>[];
- for (var i = 0; i < props.mode; i++) {
- var columns = <Widget>[];
- 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({this.borderWidth, this.blockWidth, this.mode});
- }
|