我正在尝试使用以下方法实现“圆形图标”菜单 GridView.builder
由于我使用了Column
小部件,无法访问“圆形”图标。(请参阅下面的ScreenShot)。
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('Menu'),
),
body: Padding(
padding: const EdgeInsets.all(10.0),
child: GridView.builder(
gridDelegate:
SliverGridDelegateWithFixedCrossAxisCount(crossAxisCount: 2),
itemBuilder: (context, position) {
return Padding(
padding: const EdgeInsets.all(20.0),
child: InkWell(
onTap: (){},
child: Center(
child: Column(
children: [
Card(
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.circular(100.0)),
elevation: 5,
child: Center(
child: Icon(
menuList[position].icon,
size: 50,
color: Colors.amber,
)),
),
Padding(
padding: const EdgeInsets.all(10.0),
child: Container(
alignment:Alignment.bottomCenter,
child: Text(menuList[position].title)),
)
],
),
))
);
},
itemCount: menuList.length,
),
),
);
}
我能否获得用于替换列的确切小部件??
答案 0 :(得分:1)
喜欢吗?我只移动了中心小部件。
import 'package:flutter/material.dart';
void main() => runApp(MyApp());
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter Demo',
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: Scaffold(
body: SafeArea(
child: MyHomePage(),
),
),
);
}
}
class MyHomePage extends StatefulWidget {
@override
_MyHomePageState createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
List menuList = [
_MenuItem(Icons.verified_user, 'My Profile'),
_MenuItem(Icons.autorenew, 'Book a Cab'),
_MenuItem(Icons.ac_unit, 'Booking Schedule'),
_MenuItem(Icons.center_focus_strong, 'Track Your Cab'),
_MenuItem(Icons.question_answer, 'Help & Feedback'),
_MenuItem(Icons.phone, 'Call to Transport'),
];
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('Menu'),
),
body: Padding(
padding: const EdgeInsets.all(10.0),
child: GridView.builder(
gridDelegate:
SliverGridDelegateWithFixedCrossAxisCount(crossAxisCount: 2),
itemBuilder: (context, position) {
return Padding(
padding: const EdgeInsets.all(20.0),
child: InkWell(
onTap: () {},
child: Center(
child: Column(
children: [
Center(
child: Card(
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.circular(100.0)),
elevation: 5,
child: Padding(
padding: const EdgeInsets.all(10.0),
child: Icon(
menuList[position].icon,
size: 50,
color: Colors.amber,
),
),
),
),
Padding(
padding: const EdgeInsets.all(10.0),
child: Container(
alignment: Alignment.bottomCenter,
child: Text(
menuList[position].title,
textAlign: TextAlign.center,
style: TextStyle(),
),
),
)
],
),
)));
},
itemCount: menuList.length,
),
),
);
}
}
class _MenuItem {
final IconData icon;
final String title;
_MenuItem(this.icon, this.title);
}