data:image/s3,"s3://crabby-images/b0312/b031226d6d44c79b3b9f64dfce292fc557dc53fa" alt="Buy Me a Coffee at ko-fi.com"
data:image/s3,"s3://crabby-images/829a5/829a5556c668704f4284bfcee62d52ba3b7d0c71" alt="Android Arsenal"
data:image/s3,"s3://crabby-images/16a02/16a022adebe8b6086f8f2dcdfabefcb62edb0171" alt=""
data:image/s3,"s3://crabby-images/a6e83/a6e835a3239bd32d970adeb333a4602e2802ca50" alt=""
data:image/s3,"s3://crabby-images/036c9/036c9c5d1d371220b8ecdcd5cb4c98376301e131" alt="source: imgur.com"
data:image/s3,"s3://crabby-images/214c2/214c21ff7ff4720e8ca5efaab11f6bcc6c46c8a7" alt="source: imgur.com"
Container(
padding: const EdgeInsets.all(0.0),
color: Colors.cyanAccent,
width: 80.0,
height: 80.0,
),
Note: The below example is with CrossAxisAlignment.center
.spaceEvenly |
.spaceAround |
.spaceBetween |
data:image/s3,"s3://crabby-images/bc3dd/bc3ddca974bdeda5466d5f31d0e902ffc345ae94" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/55c55/55c5532dfefad3397740e605877c04dacebf54a0" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/acd47/acd473ef66e0524e15cc125c8909157b92321d3f" alt="source: imgur.com" |
.center |
.start |
.end |
.stretch |
data:image/s3,"s3://crabby-images/24c8b/24c8b1f681c221cd91b3e44a2e589876e2daf91a" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/aaf14/aaf149e901c27170b895f636c15a5ea7e3b513b2" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/4b622/4b622f0e8f9176d271d116459ef1bbcab40c7a2b" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/c7156/c7156330f89111c4aea0bef920b0afbd34563d83" 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,
),
],
),
Note: The below example is with CrossAxisAlignment.center
.center |
.start |
.end |
.spaceEvenly |
.spaceAround |
.spaceBetween |
data:image/s3,"s3://crabby-images/dddc1/dddc191889a3dd9f7e0d368fec85e4e528f73ed3" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/32891/3289110995edda22cc1248972999fb7c36cb05e6" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/fc89b/fc89b2b22f9b1c1839004d36669a49a37c3ef73f" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/b839d/b839d9eedcf3bfb4342d41aafbb6a9ada9ff0cd5" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/52477/52477b4a542fd9de69e93e500ddd42b5c23e8d1a" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/8903d/8903db99ea204a016018a6e83feb79eb98c733fa" alt="source: imgur.com" |
.center |
.start |
.end |
.stretch |
data:image/s3,"s3://crabby-images/dddc1/dddc191889a3dd9f7e0d368fec85e4e528f73ed3" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/ff539/ff5399af0950b2fc1eafa2b55e498724bf7d9c13" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/289b0/289b0bbbd7b91fd25f9f5cc8425582c549280234" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/31803/31803902902e402a41d59c1a1d30b12ad7467e95" 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,
),
],
),
data:image/s3,"s3://crabby-images/6f110/6f110300ba47f2d8621a8557d5e9680f2a3b3bb7" 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)
.topLeft |
.topCenter |
.topRight |
data:image/s3,"s3://crabby-images/2212a/2212af9a3dbd911de423a4e48d68ec999d21aa16" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/2c260/2c26067b1f48e752b9b0ad80da01c6d389255e24" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/1505a/1505acf4935e37d7ec394f7b221b9f628baba31d" alt="source: imgur.com" |
.centerLeft |
.center |
.centerRight |
data:image/s3,"s3://crabby-images/d8bbc/d8bbcdb8d4780456d25e781d97c8202de17a028a" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/6f110/6f110300ba47f2d8621a8557d5e9680f2a3b3bb7" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/da18a/da18a416a568d8f2f5be52ebfb2bd58b1b1c6f0a" alt="source: imgur.com" |
.bottomLeft |
.bottomCenter |
.bottomRight |
data:image/s3,"s3://crabby-images/85620/85620e7ccce90e251004f94bc4d90662328dd8f3" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/119c2/119c2a4a7dea853728914fb79019883cbb0c18c7" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/02276/022766bac23dc5e60848a5ed26baf21eb5ec5e8d" 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.
data:image/s3,"s3://crabby-images/3c570/3c570c639bd92791401614e7ce1bef9db1093e10" 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,
))
data:image/s3,"s3://crabby-images/09dad/09dad60afc28b547614b06d85f23f4da46fed382" 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.
Row |
Column |
data:image/s3,"s3://crabby-images/03175/031753c4af0fcd9067ba056e1b0eed1599fc0cd1" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/c510a/c510a68e7465e86595805e4e116df43a409deead" 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,
),
],
),
Row |
Column |
data:image/s3,"s3://crabby-images/9f3cb/9f3cbb01b014c241a874ec5bf026c36fbc82038b" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/ab32f/ab32fa3d4daa69d9b47e9c87b2f1c5c3e0c38f15" 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
.
Expand |
Expand with Height |
Tight |
Loose |
data:image/s3,"s3://crabby-images/cd382/cd3829213f00d75723b1416a6af8dcca64c863be" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/f4dbb/f4dbb27a7a174e1ecd89a1a782fb61f2637367d9" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/91a06/91a06b8ff498624a21c70810780dd8ae84613986" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/d8ca4/d8ca4c1804c7f487047d8b702ac0abe0b5d8960f" 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),)),
))
AlignmentDirectional.centerStart |
AlignmentDirectional.center |
AlignmentDirectional.centerEnd |
data:image/s3,"s3://crabby-images/067e2/067e2c8c248b642518e1876212ef98c1ff93982e" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/fe9f1/fe9f1dd69374b302e30fa93915f9879f2be69c79" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/76bd5/76bd56338d58ae669abccd7d0b0fdea25f241cd3" alt="source: imgur.com" |
AlignmentDirectional.bottomStart |
AlignmentDirectional.bottomCenter |
AlignmentDirectional.bottomEnd |
data:image/s3,"s3://crabby-images/5a9f7/5a9f7c28d76f5ef7e7565128f036510509300fb9" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/2d7e9/2d7e919704035fd6c6567468bb2da6dbcc6a4022" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/b796d/b796d995b91c89028f55b2d0babcfb4bc869aa51" alt="source: imgur.com" |
AlignmentDirectional.topStart |
AlignmentDirectional.topCenter |
AlignmentDirectional.topEnd |
data:image/s3,"s3://crabby-images/9fa6a/9fa6a2a94313e23178d121460161cc8bf8b5ebcc" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/a5809/a5809ea252f930946b4d3393ed689992a1eabe5a" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/72209/72209d9d2a2b7d6a7ed7e070fb84e461ab06aae7" 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
data:image/s3,"s3://crabby-images/35f59/35f59df139e078b7d81dd1689668e53254b2fe6f" 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,
),
],
)
data:image/s3,"s3://crabby-images/67eef/67eef6f8f53e86edf5463f19d9b064aedbe2aed7" 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)),
],
),
)
data:image/s3,"s3://crabby-images/83315/83315cb65cd79f0c149a6f29d88e6f4164aa06ec" 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: new Scaffold(
appBar: AppBar(title: Text('ListView')),
body: Center(
child:
new ListView.builder(
itemCount: names.length,
itemBuilder: (BuildContext context, int position) {
var name = names[position];
return ListTile(title: Text(name));
}),
)),
);
}
data:image/s3,"s3://crabby-images/59281/59281d3b14b71b29945b3e625609f2fbe7d16d52" 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),
data:image/s3,"s3://crabby-images/35606/35606053b7836b5d3e0437d1e6c939229b567217" 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)));
})
data:image/s3,"s3://crabby-images/62e72/62e72bb0f165dba644b71299e5132757aab51ecb" alt="source: imgur.com"
new Text(
"Flutter is Awesome",
style: new TextStyle(
fontSize: 18.0,
color: Colors.greenAccent,
fontWeight: FontWeight.w500,
fontFamily: "Roboto"),
),
data:image/s3,"s3://crabby-images/6426f/6426fdcfbb0ffdfc6dc1fdb7666d77658fe61b90" alt="source: imgur.com"
new Icon(Icons.flight_takeoff, color: Colors.blueAccent, size: 96.0),
data:image/s3,"s3://crabby-images/0d25c/0d25cffcc3345bdcaae562a9d54b537ea1867010" 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'),
),
data:image/s3,"s3://crabby-images/f8a16/f8a167c82e11819fb6bdd0f3e7af003f8e8aa6a4" 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'),
),
data:image/s3,"s3://crabby-images/c9437/c9437f2f15a02f6a9db4a1b8c4d8171137446782" alt="source: imgur.com"
IconButton(
onPressed: () {
debugPrint("Starred Me!");
},
color: Colors.orangeAccent,
icon: Icon(Icons.star),
disabledColor: Colors.grey,
highlightColor: Colors.black38,
),
Normal |
Mini |
data:image/s3,"s3://crabby-images/55730/557307b0aaf44b6dc5fd3819994bb9b7a1b5aa3a" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/9fbf0/9fbf0bd7b89b647b59a474680ac582f8c2b4918d" alt="source: imgur.com" |
-------- |
mini: true |
return Scaffold(
floatingActionButton: new FloatingActionButton(
mini: true,
child: new Icon(Icons.add),
onPressed: () {},
),
);
DropdownButton |
DropdownMenuItem |
data:image/s3,"s3://crabby-images/b2519/b2519725448811bd16cb34f522ef2b41739babdb" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/9b40c/9b40cfac4b2229bdbaab65be75a05b0b67a1bd93" 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});
}
data:image/s3,"s3://crabby-images/36ae3/36ae398811306e4c35a6eb9460ef1b7cb0218cf9" 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);
}),
],
),
),
);
}
(Text box or Edit Text)
Simple |
Icon |
data:image/s3,"s3://crabby-images/073f8/073f8747af8cece59aebdc88280438e6bdab8d08" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/c23fc/c23fc1ce5dde7c4cbea002a6c5d1f16bb78d54cf" alt="source: imgur.com" |
Prefix |
Suffix |
data:image/s3,"s3://crabby-images/07233/0723353f8267eef9ff23fbfcfdfe60eaaccde6ec" alt="source: imgur.com" |
data:image/s3,"s3://crabby-images/6c7bf/6c7bfaba54bd6a15bc3697ff7da004717f763777" 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)) |
data:image/s3,"s3://crabby-images/995e6/995e6f9343e7009b26326c40d3045270c3b9b9cd" 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
data:image/s3,"s3://crabby-images/50865/50865ceea660a0a3ce261269b3640e2f77b42ca8" 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))
)
References:
- https://medium.com/@anilcan/forms-in-flutter-6e1364eafdb5
- https://codingwithjoe.com/building-forms-with-flutter/
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);
}