You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

67 lines
2.1 KiB

import 'package:flutter/material.dart';
class Grid extends StatelessWidget {
const Grid({
Key? key,
required this.number,
required this.onTap,
required this.color,
required this.puzzleSize,
}) : super(key: key);
final Function onTap;
final List<dynamic> number;
final Color color;
final int puzzleSize;
@override
Widget build(BuildContext context) {
var screenSize = MediaQuery.of(context).size;
return SizedBox(
height: screenSize.height * 0.7,
width: screenSize.width * 0.4,
child: GridView.builder(
gridDelegate: SliverGridDelegateWithFixedCrossAxisCount(
crossAxisCount: puzzleSize,
),
itemCount: number.length,
itemBuilder: (context, index) {
return number[index] != 0
? MouseRegion(
child: Padding(
padding: const EdgeInsets.all(2.0),
child: GestureDetector(
onTap: () => onTap(index),
child: Card(
elevation: 4,
color: color,
// dark -> 0xFF14407a
// light -> 0xFF43b9fd
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.circular(20),
),
child: SizedBox(
height: 20,
width: 20,
child: Center(
child: Text(
number[index].toString(),
style: const TextStyle(
fontSize: 60,
fontWeight: FontWeight.bold,
color: Colors.white,
),
),
),
),
),
),
),
)
: const SizedBox();
},
),
);
}
}