data:image/s3,"s3://crabby-images/02e48/02e48e36c6aa590d53d61ab9677f50e2b91c5b75" alt="Buy Me a Coffee at ko-fi.com"
data:image/s3,"s3://crabby-images/6e732/6e73265c531b25a0d25b79149a5160e6f41f076f" alt="Android Arsenal"
data:image/s3,"s3://crabby-images/9a3a1/9a3a1d6b64ce63b27c63707fd2da7b467e7916db" alt=""
data:image/s3,"s3://crabby-images/ff3fa/ff3faff867eeba728675da9ac767e4f42a38547c" alt=""
data:image/s3,"s3://crabby-images/c7e13/c7e134379cd0384f6bd31a76e0f6d1355ca4649c" alt="source: imgur.com"
-
Layouts
-
Container
-
Row
-
MainAxisAlignment
-
CrossAxisAlignment
-
Column
-
MainAxisAlignment
-
CrossAxisAlignment
-
Center
-
Align
-
Padding
-
SizedBox
-
Expanded
-
Flexible
-
ConstrainedBox
-
Stack
-
Wrap
-
Positioned
-
ListView
-
Text
-
Icon
-
Material
-
Button
-
Material Button
-
Flat Button
-
Raised Button
-
Icon Button
-
Floating Action Button
-
DropdownButton
-
Radio Button
-
Input Field
-
TextField
-
Under Line Style
-
Outer Line Style
-
TextFormField
-
Navigation Drawer
-
Sliver List
-
Utilities
Layouts
Container
data:image/s3,"s3://crabby-images/471bc/471bcb16f4a58b3e6473062a3ca8b34511ba8064" alt="source: imgur.com"
Container(
padding: const EdgeInsets.all(0.0),
color: Colors.cyanAccent,
width: 80.0,
height: 80.0,
),
Row
MainAxisAlignment
Note: The below example is with CrossAxisAlignment.center
.spaceEvenly |
.spaceAround |
.spaceBetween |
data:image/s3,"s3://crabby-images/ea46a/ea46ac29ce6a6e1503b665cfb51e6b4c2c2adfe1" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/0ef32/0ef32a3c40b2bf9c8b4d2186d832d19b6b3b3301" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/7a64e/7a64e37696c639657b3137fdac26c2185ce31ad5" alt="source: imgur.com" |
CrossAxisAlignment
.center |
.start |
.end |
.stretch |
data:image/s3,"s3://crabby-images/9cf09/9cf09d908c4a4a3fe7b44ca43c04681b24c46d31" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/ddfc1/ddfc11e85e07c3e48b85656feea3cdd94208f6df" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/09921/099216f3af63aec1ff1b66c423a67ca3b2b80a64" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/f3dd2/f3dd2694e91ce1662a2ceba870dc0f8759b25f6a" alt="source: imgur.com" |
Row(
mainAxisAlignment: MainAxisAlignment.center,
mainAxisSize: MainAxisSize.max,
crossAxisAlignment: CrossAxisAlignment.center,
children: <Widget>[
Container(
padding: const EdgeInsets.all(0.0),
color: Colors.cyanAccent,
width: 80.0,
height: 80.0,
),
Container(
padding: const EdgeInsets.all(0.0),
color: Colors.blueAccent,
width: 80.0,
height: 80.0,
),
Container(
padding: const EdgeInsets.all(0.0),
color: Colors.orangeAccent,
width: 80.0,
height: 80.0,
),
],
),
Column
MainAxisAlignment
Note: The below example is with CrossAxisAlignment.center
.center |
.start |
.end |
.spaceEvenly |
.spaceAround |
.spaceBetween |
data:image/s3,"s3://crabby-images/0dad6/0dad65023441f544a74309bfe8f1631f4b978a0b" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/e0053/e0053dc69b70da348268c5f2b38467abe250602a" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/43bb2/43bb27aed016a8a4bbd8cb6b22a3268e51b75978" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/2a196/2a196dd8e614c392f62b44129e8108f0dd8f7536" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/93256/9325630167bc74f69483433161ac89ea165d3923" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/df2a1/df2a1fafac92cfb1114d80fabef18c0b7ca6c64c" alt="source: imgur.com" |
CrossAxisAlignment
.center |
.start |
.end |
.stretch |
data:image/s3,"s3://crabby-images/0dad6/0dad65023441f544a74309bfe8f1631f4b978a0b" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/d7bb2/d7bb2651660297908623af303c43cabf6e66b087" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/e08e0/e08e02bc3e4d7547b88f8c24959fc4ca5571dcb2" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/f1a7c/f1a7c26bcd6794b338bfd7a11b7e9017ab5df6a3" alt="source: imgur.com" |
Column(
mainAxisAlignment: MainAxisAlignment.center,
mainAxisSize: MainAxisSize.max,
crossAxisAlignment: CrossAxisAlignment.center,
children: <Widget>[
Container(
padding: const EdgeInsets.all(0.0),
color: Colors.cyanAccent,
width: 80.0,
height: 80.0,
),
Container(
padding: const EdgeInsets.all(0.0),
color: Colors.blueAccent,
width: 80.0,
height: 80.0,
),
Container(
padding: const EdgeInsets.all(0.0),
color: Colors.orangeAccent,
width: 80.0,
height: 80.0,
),
],
),
Center
data:image/s3,"s3://crabby-images/0af03/0af03c93557cccb03107132d6cdc73fe45db480c" alt="source: imgur.com"
Center(child: Container(
padding: const EdgeInsets.all(0.0),
color: Colors.cyanAccent,
width: 80.0,
height: 80.0,
))
Note: Center wraps any widget to center to its parent widget. (i.e orange is the parent widget)
Align
.topLeft |
.topCenter |
.topRight |
data:image/s3,"s3://crabby-images/0b566/0b566ad8d2ebd41c7fabb3b6457a9da86b929a10" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/ffaca/ffacacca817b1b8b9f0722dbd626eb44ccc4dc47" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/f2f6d/f2f6d3c0d490f436bfc7dca3280253b099c08631" alt="source: imgur.com" |
.centerLeft |
.center |
.centerRight |
data:image/s3,"s3://crabby-images/813a2/813a22adc31e5e4c6763d50361f3ef7ef8ab4529" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/0af03/0af03c93557cccb03107132d6cdc73fe45db480c" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/4dee2/4dee200534098d2f65100c83b28b8614036fb06c" alt="source: imgur.com" |
.bottomLeft |
.bottomCenter |
.bottomRight |
data:image/s3,"s3://crabby-images/6b18d/6b18d389a33be932579eb73d2646c05e8e5690cd" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/66ab4/66ab4ab009d22836e4eb8fbd6fadc1f315b9c3fd" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/128e7/128e758fc084bcf6dc5177dfb7c981879efd8003" alt="source: imgur.com" |
Align(
alignment: Alignment.center,
child: Container(
padding: const EdgeInsets.all(0.0),
color: Colors.cyanAccent,
width: 80.0,
height: 80.0,
))
Note: Align wraps any widget based on the Alignment direction to its parent widget. The default alignment for Align is center.
Padding
data:image/s3,"s3://crabby-images/42aa2/42aa2da40deb20dc558f668b52ab464b115f8b89" alt="source: imgur.com"
Padding(
padding: EdgeInsets.fromLTRB(24, 32, 24, 32) ,
child: Container(
padding: const EdgeInsets.all(0.0),
color: Colors.cyanAccent,
width: 80.0,
height: 80.0,
))
SizedBox
data:image/s3,"s3://crabby-images/eed5e/eed5eb86968cedb5522af1ecf0701bfff7145e3f" alt="source: imgur.com"
SizedBox(
width: 200.0,
height: 100.0,
child: Card(
color: Colors.indigoAccent,
child: Center(
child: Text('SizedBox',
style: TextStyle(color: Colors.white)
)
)
)
)
Note: SizedBox constraints its child widget to match based on specific size of width and height.
Expanded
Row |
Column |
data:image/s3,"s3://crabby-images/35c06/35c06a28e496ef980794879b478e9b4307d7a364" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/f257a/f257accb57d9396207c41bd48ff8663da8157e5d" alt="source: imgur.com" |
Row(
mainAxisAlignment: MainAxisAlignment.center,
mainAxisSize: MainAxisSize.max,
crossAxisAlignment: CrossAxisAlignment.center,
children: <Widget>[
Expanded(
child: Container(color: Colors.cyan, height: 80),
flex: 2,
),
Expanded(
child: Container(color: Colors.indigoAccent, height: 80),
flex: 3,
),
Expanded(
child: Container(color: Colors.orange, height: 80),
flex: 4,
),
],
),
Flexible
Row |
Column |
data:image/s3,"s3://crabby-images/34d82/34d8293929359d17e62875d26625363b3d43a7f8" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/5e940/5e9400df1fc519a5c4bc7d7114998dca3ad8ace4" alt="source: imgur.com" |
Row(
mainAxisAlignment: MainAxisAlignment.center,
mainAxisSize: MainAxisSize.max,
crossAxisAlignment: CrossAxisAlignment.center,
children: <Widget>[
Flexible(
child: Container(color: Colors.cyanAccent, height: 80, width: 80),
flex: 2,
),
Flexible(
child: Container(color: Colors.indigoAccent, height: 80, width: 80),
flex: 3,
),
Flexible(
child: Container(color: Colors.orange, height: 80, width: 80),
flex: 4,
),
],
),
Hint:
- To make Flexible behave similar to Expanded, then add
fit: FlexFit.tight
- By default fit type for Flexible is
fit: FlexFit.loose
.
ConstrainedBox
Expand |
Expand with Height |
Tight |
Loose |
data:image/s3,"s3://crabby-images/42194/4219494c26030c182ab3c0078ec83fb71cbfc4e0" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/80c72/80c7221a8d6106636d5abc218c0547c7675f9132" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/ced4c/ced4ccd7a8df39adb7f400fc8f302c607f1d2b40" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/f3ea3/f3ea31c97ab5afc828369227a0117cb0971a5c80" alt="source: imgur.com" |
BoxConstraints.expand() |
BoxConstraints.expand(height: 100) |
BoxConstraints.tight(Size(125, 100)) |
BoxConstraints.loose(Size(125, 100)) |
ConstrainedBox(
constraints: BoxConstraints.expand(height: 100),
child: Container(
color: Colors.orange,
child: Padding(padding: EdgeInsets.all(16), child: Text('Box Constraint', style: TextStyle(color: Colors.white),)),
))
Stack
AlignmentDirectional.centerStart |
AlignmentDirectional.center |
AlignmentDirectional.centerEnd |
data:image/s3,"s3://crabby-images/23922/23922d5fdae7999648078dd1174d03405dc57751" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/d9bd0/d9bd0bb3a3741022760de8843532265795cfe3f9" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/7d02c/7d02c0c1afcae3b3221ebdba5ffd81d08afe7f29" alt="source: imgur.com" |
AlignmentDirectional.bottomStart |
AlignmentDirectional.bottomCenter |
AlignmentDirectional.bottomEnd |
data:image/s3,"s3://crabby-images/3b37c/3b37cee7fa68683aede7829ad2d71af9b647b887" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/15248/15248da68a443aa9f58916d9229899f8d0074452" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/09838/09838c5eb8c112db9657c9b3b6c87fd11a7b8c49" alt="source: imgur.com" |
AlignmentDirectional.topStart |
AlignmentDirectional.topCenter |
AlignmentDirectional.topEnd |
data:image/s3,"s3://crabby-images/3d1e5/3d1e52d89bdefcd8ac70fc3da7064da14c821beb" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/0c9ad/0c9adbe612720087ba2fd774e42f38b7894a207d" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/39a8e/39a8e607f1722da1587f4b2ca4e12d59076da665" alt="source: imgur.com" |
Stack(
alignment: AlignmentDirectional.center,
children: [
Container(
height: 200.0,
width: 200.0,
color: Colors.red,
),
Container(
height: 150.0,
width: 150.0,
color: Colors.blue,
),
Container(
height: 100.0,
width: 100.0,
color: Colors.green,
),
Container(
height: 50.0,
width: 50.0,
color: Colors.yellow,
),
],
),
Credits: Fore more detailed blog post for this. Please visit https://medium.com/flutter-community/flutter-for-android-developers-how-to-design-framelayout-in-flutter-93a19fc7e7a6
Wrap
data:image/s3,"s3://crabby-images/7cfeb/7cfeb73bdc34a367b22f13ac77a218cf4da16e57" alt="source: imgur.com"
Wrap(
spacing: 4.0, // gap between lines
children: <Widget>[
Chip(
avatar: CircleAvatar(backgroundColor: Colors.orange, child: Text('C', style: TextStyle(color: Colors.white))),
label: Text('Cupcake'),
backgroundColor: Colors.white,
),
Chip(
avatar: CircleAvatar(backgroundColor: Colors.cyanAccent, child: Text('D', style: TextStyle(color: Colors.black45))),
label: Text('Donut'),
backgroundColor: Colors.white,
),
Chip(
avatar: CircleAvatar(backgroundColor: Colors.indigoAccent, child: Text('E', style: TextStyle(color: Colors.white))),
label: Text('Eclair'),
backgroundColor: Colors.white,
),
Chip(
avatar: CircleAvatar(backgroundColor: Colors.yellowAccent, child: Text('F', style: TextStyle(color: Colors.black45))),
label: Text('Froyo'),
backgroundColor: Colors.white,
),
Chip(
avatar: CircleAvatar(backgroundColor: Colors.green, child: Text('G', style: TextStyle(color: Colors.white))),
label: Text('Gingerbread'),
backgroundColor: Colors.white,
),
Chip(
avatar: CircleAvatar(backgroundColor: Colors.redAccent, child: Text('H', style: TextStyle(color: Colors.white))),
label: Text('Honeycomb'),
backgroundColor: Colors.white,
),
Chip(
avatar: CircleAvatar(backgroundColor: Colors.greenAccent, child: Text('I', style: TextStyle(color: Colors.black45))),
label: Text('Ice cream Sandwich'),
backgroundColor: Colors.white,
),
Chip(
avatar: CircleAvatar(backgroundColor: Colors.deepOrangeAccent, child: Text('J', style: TextStyle(color: Colors.white))),
label: Text('Jelly Bean'),
backgroundColor: Colors.white,
),
Chip(
avatar: CircleAvatar(backgroundColor: Colors.indigo, child: Text('K', style: TextStyle(color: Colors.white))),
label: Text('Kit Kat'),
backgroundColor: Colors.white,
),
Chip(
avatar: CircleAvatar(backgroundColor: Colors.tealAccent, child: Text('L', style: TextStyle(color: Colors.black45))),
label: Text('Lollipop'),
backgroundColor: Colors.white,
),
Chip(
avatar: CircleAvatar(backgroundColor: Colors.amberAccent, child: Text('M', style: TextStyle(color: Colors.white))),
label: Text('Marshmallow'),
backgroundColor: Colors.white,
),
Chip(
avatar: CircleAvatar(backgroundColor: Colors.cyan, child: Text('N', style: TextStyle(color: Colors.white))),
label: Text('Nougat'),
backgroundColor: Colors.white,
),
Chip(
avatar: CircleAvatar(backgroundColor: Colors.red, child: Text('O', style: TextStyle(color: Colors.white))),
label: Text('Oreo'),
backgroundColor: Colors.white,
),
Chip(
avatar: CircleAvatar(backgroundColor: Colors.greenAccent, child: Text('P', style: TextStyle(color: Colors.black45))),
label: Text('Pie'),
backgroundColor: Colors.white,
),
],
)
Positioned
data:image/s3,"s3://crabby-images/101c3/101c357777b0239b755b63f6cf1127841b72f4dd" alt="source: imgur.com"
ConstrainedBox(
constraints: BoxConstraints.tight(Size(double.infinity, 256)),
child: Stack(
alignment: AlignmentDirectional.center,
children: <Widget>[
Positioned(
top: 0.0,
child: Icon(Icons.calendar_today,
size: 128.0, color: Colors.lightBlueAccent),
),
Positioned(
top: 4,
right: 110,
child: CircleAvatar(radius: 16, backgroundColor: Colors.red)),
],
),
)
ListView
Simple
data:image/s3,"s3://crabby-images/41847/41847b9780ee77ee0132ee0b63696be8839b4387" alt="source: imgur.com"
@override
Widget build(BuildContext context) {
List<String> names = ['Alpha', 'Beta', 'Cupcake', 'Donut', 'Eclair',
'Froyo', 'Ginger bread', 'Honey comb', 'Ice cream sandwich', 'Jelly bean',
'Kitkat', 'Lollipop', 'Marshmallow', 'Nougat', 'Oreo', 'Pie'
];
return MaterialApp(
debugShowCheckedModeBanner: false,
home: Scaffold(
appBar: AppBar(title: Text('ListView')),
body: Center(
child:
ListView.builder(
itemCount: names.length,
itemBuilder: (BuildContext context, int position) {
var name = names[position];
return ListTile(title: Text(name));
}),
)),
);
}
Divider
data:image/s3,"s3://crabby-images/d2cef/d2cefee3e8fe6af892be6a4af0b91b578c2f4d1a" alt="source: imgur.com"
ListView.separated(
itemBuilder: (BuildContext context, int position) {
var name = names[position];
return ListTile(title: Text(name));
},
separatorBuilder: (BuildContext context, int index) =>
Divider(),
itemCount: names.length),
Card
data:image/s3,"s3://crabby-images/a16c5/a16c58270ce84bdc1f7ccd97866ed5894846bd2f" alt="source: imgur.com"
ListView.builder(
itemCount: names.length,
itemBuilder: (BuildContext context, int position) {
var name = names[position];
return Card(margin: EdgeInsets.fromLTRB(8, 4, 8, 4),child: ListTile(title: Text(name)));
})
Text
data:image/s3,"s3://crabby-images/0cfb7/0cfb74e250addfa71454bbe11b034637c9f23d8a" alt="source: imgur.com"
Text(
"Flutter is Awesome",
style: TextStyle(
fontSize: 18.0,
color: Colors.greenAccent,
fontWeight: FontWeight.w500,
fontFamily: "Roboto"),
),
Icon
data:image/s3,"s3://crabby-images/90890/908901e1c76c5843d0111a3314ef9ac1026853c6" alt="source: imgur.com"
new Icon(Icons.flight_takeoff, color: Colors.blueAccent, size: 96.0),
Material
Button
Material Button
data:image/s3,"s3://crabby-images/897ac/897acef28c019cc5bb95659a0395800adeb0da9d" alt="source: imgur.com"
MaterialButton(
onPressed: () {
debugPrint('I am a material button');
},
shape: const StadiumBorder(),
textColor: Colors.black,
color: Colors.blue[300],
splashColor: Colors.blue[900],
disabledColor: Colors.grey,
disabledTextColor: Colors.white,
child: Text('Material Button'),
),
Flat Button
data:image/s3,"s3://crabby-images/0d039/0d0396439a613949deaad12409d268a611f71729" alt="source: imgur.com"
FlatButton(
onPressed: () {
debugPrint('I am Awesome');
},
textColor: Colors.white,
color: Colors.blueAccent,
disabledColor: Colors.grey,
disabledTextColor: Colors.white,
highlightColor: Colors.orangeAccent,
child: Text('Flat Button'),
),
Raised Button
data:image/s3,"s3://crabby-images/236c8/236c8c19cb3887e4d0ba8b6c737e60a2a6b0bded" alt="source: imgur.com"
RaisedButton(
onPressed: () {
debugPrint('I am Awesome');
},
textColor: Colors.white,
color: Colors.blueAccent,
disabledColor: Colors.grey,
disabledTextColor: Colors.white,
highlightColor: Colors.orangeAccent,
elevation: 4.0,
child: Text('Raised Button'),
),
Icon Button
data:image/s3,"s3://crabby-images/cb189/cb18985288dfdb362912d51ea49f12f286f7dbbe" alt="source: imgur.com"
IconButton(
onPressed: () {
debugPrint("Starred Me!");
},
color: Colors.orangeAccent,
icon: Icon(Icons.star),
disabledColor: Colors.grey,
highlightColor: Colors.black38,
),
Floating Action Button
(FAB)
Normal |
Mini |
data:image/s3,"s3://crabby-images/6d42a/6d42a46270e27d6564b64d6a6839c0d067801d63" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/77316/77316e02c13b5afa99be1bf673ad3179d019641a" alt="source: imgur.com" |
-------- |
mini: true |
Scaffold(
floatingActionButton: new FloatingActionButton(
mini: true,
child: new Icon(Icons.add),
onPressed: () {},
),
);
DropdownButton
DropdownButton |
DropdownMenuItem |
data:image/s3,"s3://crabby-images/53723/53723587252cf6a9e3fa6dc70f6f066271c88127" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/7d84c/7d84c7267b290f29210033c8f36f71041c7bf168" alt="source: imgur.com" |
import 'package:flutter/material.dart';
class CustomDropDownWidget extends StatefulWidget {
@override
ChangeBGColorDropdownState createState() {
return new ChangeBGColorDropdownState();
}
}
class ChangeBGColorDropdownState extends State<CustomDropDownWidget> {
List<DropDownItemModel> _dropDownItemModelList = [
DropDownItemModel(versionName: "Cupcake"),
DropDownItemModel(versionName: "Donut"),
DropDownItemModel(versionName: "Eclair"),
DropDownItemModel(versionName: "Froyo"),
];
DropDownItemModel _dropDownItemModel;
@override
void initState() {
super.initState();
_dropDownItemModel = _dropDownItemModelList[0];
}
@override
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
body: Center(
child: Container(
padding: EdgeInsets.fromLTRB(16, 0, 16, 0),
color: Colors.orangeAccent,
child: DropdownButton<DropDownItemModel>(
underline: Container(
decoration: const BoxDecoration(
border: Border(bottom: BorderSide(color: Colors.transparent))
),
),
iconEnabledColor: Colors.white,
items: _dropDownItemModelList
.map((dropDownItemModel) =>
DropdownMenuItem<DropDownItemModel>(
child: Text(dropDownItemModel.versionName),
value: dropDownItemModel,
))
.toList(),
onChanged: (DropDownItemModel dropDownItemModel) {
setState(() => _dropDownItemModel = dropDownItemModel);
},
hint: Text(
_dropDownItemModel.versionName,
style: TextStyle(color: Colors.white),
),
),
),
),
),
);
}
}
class DropDownItemModel {
String versionName;
DropDownItemModel({this.versionName});
}
Radio Button
Vertical
data:image/s3,"s3://crabby-images/b8470/b8470c70d61527c459e8bd3c8ba3b37d43fbd7b4" alt="source: imgur.com"
import 'package:flutter/material.dart';
enum Gender { MALE, FEMALE, OTHER }
class RadioButton extends StatefulWidget {
@override
_RadioButtonState createState() => _RadioButtonState();
}
class _RadioButtonState extends State<RadioButton> {
Gender _genderValue = Gender.MALE;
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
body: Column(
mainAxisAlignment: MainAxisAlignment.center,
crossAxisAlignment: CrossAxisAlignment.center,
children: <Widget>[
RadioListTile(
title: const Text('Male'),
value: Gender.MALE,
groupValue: _genderValue,
onChanged: (Gender value) {
setState(() {
_genderValue = value;
});
},
),
RadioListTile(
title: const Text('Female'),
value: Gender.FEMALE,
groupValue: _genderValue,
onChanged: (Gender value) {
setState(() {
_genderValue = value;
});
},
),
RadioListTile(
title: const Text('Other'),
value: Gender.OTHER,
groupValue: _genderValue,
onChanged: (Gender value) {
setState(() {
_genderValue = value;
});
},
),
],
),
),
);
}
}
Horizontal
data:image/s3,"s3://crabby-images/6246c/6246c2ea553da3bfb1e1d29e16977c29ec9ffa96" alt="source: imgur.com"
import 'package:flutter/material.dart';
enum Gender { MALE, FEMALE, OTHER }
class RadioButtonHorizontal extends StatefulWidget {
@override
_RadioButtonHorizontalState createState() => _RadioButtonHorizontalState();
}
class _RadioButtonHorizontalState extends State<RadioButtonHorizontal> {
Gender _genderValue = Gender.MALE;
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
body: Center(
child: Row(
mainAxisAlignment: MainAxisAlignment.center,
crossAxisAlignment: CrossAxisAlignment.center,
children: <Widget>[
FlatButton.icon(
label: const Text('Male'),
icon: Radio(
value: Gender.MALE,
groupValue: _genderValue,
onChanged: (Gender value) {
setState(() {
_genderValue = value;
});
},
),
onPressed: () {
setState(() {
_genderValue = Gender.MALE;
});
},
),
FlatButton.icon(
label: const Text('Female'),
icon: Radio(
value: Gender.FEMALE,
groupValue: _genderValue,
onChanged: (Gender value) {
setState(() {
_genderValue = value;
});
},
),
onPressed: () {
setState(() {
_genderValue = Gender.FEMALE;
});
},
),
FlatButton.icon(
label: const Text('Others'),
icon: Radio(
value: Gender.OTHER,
groupValue: _genderValue,
onChanged: (Gender value) {
setState(() {
_genderValue = value;
});
},
),
onPressed: () {
setState(() {
_genderValue = Gender.OTHER;
});
},
)
],
),
),
),
);
}
}
Navigation Drawer
data:image/s3,"s3://crabby-images/50de6/50de6b277f8ef1eeb8d6f61285cfc224f7000522" alt="source: imgur.com"
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
backgroundColor: AppColors.gradient_purple_begin,
title: Text("XSpends")),
drawer: new Drawer(
child: new ListView(
children: <Widget>[
new UserAccountsDrawerHeader(
accountName: new Text("TakeoffAndroid"),
accountEmail: new Text("[email protected]"),
currentAccountPicture: CircleAvatar(
backgroundColor: Colors.yellow,
child: Text('T', style: TextStyle(color: Colors.black87))
),
decoration: new BoxDecoration(
gradient: LinearGradient(
begin: Alignment.centerLeft,
end: Alignment.centerRight,
colors: [
AppColors.gradient_purple_begin,
AppColors.gradient_purple_end
]),
),
),
new ListTile(
leading: Icon(Icons.home),
title: new Text("Home"),
onTap: () {
Navigator.pop(context);
}),
new ListTile(
leading: Icon(Icons.person),
title: new Text("Friends"),
onTap: () {
Navigator.pop(context);
}),
new ListTile(
leading: Icon(Icons.share),
title: new Text("Share"),
onTap: () {
Navigator.pop(context);
}),
new Divider(),
new ListTile(
leading: Icon(Icons.settings),
title: new Text("Settings"),
onTap: () {
Navigator.pop(context);
}),
new ListTile(
leading: Icon(Icons.power_settings_new),
title: new Text("Logout"),
onTap: () {
Navigator.pop(context);
}),
],
),
),
);
}
Input Field
TextField
(Text box or Edit Text)
Under Line Style
Simple |
Icon |
data:image/s3,"s3://crabby-images/56b45/56b45036c39d32275262a12afaacd56a7e981de2" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/40dec/40dec9320797c6d7c8b7a976b69ebcbadf7e9d9b" alt="source: imgur.com" |
Prefix |
Suffix |
data:image/s3,"s3://crabby-images/ea38a/ea38a455b5f7d421e0b3ba34aafc49886c49bea1" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/dd57f/dd57f128c165c7d8733b2140fa985cf1fe89ea77" alt="source: imgur.com" |
TextField(
decoration: InputDecoration(
hintText: "Enter your name!",
hintStyle: TextStyle(fontWeight: FontWeight.w300, color: Colors.blue),
enabledBorder: new UnderlineInputBorder(
borderSide: new BorderSide(color: Colors.blue)),
focusedBorder: UnderlineInputBorder(
borderSide: BorderSide(color: Colors.orange),
),
),
)
Icon |
Prefix |
Suffix |
InputDecoration(icon: Icon(Icons.account_circle, color: Colors.blue)) |
InputDecoration(prefixIcon: Icon(Icons.account_circle, color: Colors.blue)) |
InputDecoration(suffixIcon: Icon(Icons.account_circle, color: Colors.blue)) |
Outer Line Style
data:image/s3,"s3://crabby-images/f21c0/f21c0e3e1edf4df7ad24c0887af58796698ba5a5" alt="source: imgur.com"
TextField(
decoration: InputDecoration(
hintText: "Enter your name!",
hintStyle: TextStyle(fontWeight: FontWeight.w300, color: Colors.blue),
enabledBorder: new OutlineInputBorder(
borderSide: new BorderSide(color: Colors.blue)),
focusedBorder: OutlineInputBorder(
borderSide: BorderSide(color: Colors.orange),
),
),
)
Note: Icon, Prefix Icon and Suffix Icon are similar to Underline TextField
TextFormField
data:image/s3,"s3://crabby-images/4323a/4323a2012c300486188f20af3517e0b3cb356eee" alt="source: imgur.com"
TextFormField(
style: TextStyle(color: Colors.white),
obscureText: true, // Use secure text for passwords.
decoration: InputDecoration(
enabledBorder: UnderlineInputBorder(borderSide: BorderSide(color: Colors.white)),
focusedBorder: UnderlineInputBorder(
borderSide: BorderSide(color: Colors.yellow)
),
hintText: 'Password',
hintStyle: TextStyle(color: Colors.white),
labelText: 'Type your password',
labelStyle: TextStyle(color: Colors.yellow))
)
Sliver List
data:image/s3,"s3://crabby-images/a873d/a873deb43694a64cc327d639949247be3c98a58e" alt="slivers2"
-
SliverList takes a delegate parameter which provides the items in the list as they scroll into view.
-
You can specify the actual list of children with a SliverChildListDelegate Or build them lazily with a SliverChildBuilderDelegate.
SliverList(
delegate: SliverChildListDelegate(
[
Container(color: Colors.red, height: 150.0),
Container(color: Colors.purple, height: 150.0),
Container(color: Colors.green, height: 150.0),
],
),
);
// This builds an infinite scrollable list of differently colored
// Containers.
SliverList(
delegate: SliverChildBuilderDelegate((BuildContext context, int index) {
// To convert this infinite list to a list with three items,
// uncomment the following line:
// if (index > 3) return null;
return Container(color: getRandomColor(), height: 150.0);
},
// Or, uncomment the following line:
// childCount: 3,
),
);
References:
- https://medium.com/@anilcan/forms-in-flutter-6e1364eafdb5
- https://codingwithjoe.com/building-forms-with-flutter/
Utilities
Creates Color Utils
class AppColors {
static const Color colorPrimary = Color.fromARGB(255, 51, 51, 51);
static const Color colorPrimaryDark = Color.fromARGB(255, 41, 41, 41);
static const Color colorAccent = Color.fromARGB(255, 30, 198, 89);
static const Color yellow = Color.fromARGB(255, 252, 163, 38);
static const Color orange = Color.fromARGB(255, 252, 109, 38);
static const Color grey_unselected = Color.fromARGB(255, 96, 96, 96);
static const Color white_card = Color.fromARGB(255, 250, 250, 250);
static const Color chrome_grey = Color.fromARGB(255, 240, 240, 240);
static const Color white = Color.fromARGB(255, 255, 255, 255);
static const Color white_secondary = Color.fromARGB(255, 220, 220, 220);
static const Color white_un_selected = Color.fromARGB(255, 180, 180, 180);
static const Color indigo = Color.fromARGB(255, 51, 105, 231);
static const Color primary_text = Color.fromARGB(255, 51, 51, 51);
static const Color secondary_text = Color.fromARGB(255, 114, 114, 114);
static const Color grey = Color.fromARGB(255, 188, 187, 187);
}