Basic file setup
Create a new Flutter project or open an existing one. We will add examples of each button in the main.dart file.
import 'package:flutter/material.dart';
void main() {
runApp(const MainApp());
}
class MainApp extends StatelessWidget {
const MainApp({super.key});
@override
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
body: Center(
child: //add code here
)
),
);
}
}
ElevatedButton
An ElevatedButton
is a material button that has elevation, which gives it a shadow effect. It’s commonly used for primary actions.
data:image/s3,"s3://crabby-images/5464c/5464c699560af97acc4a4c9cdd2aeb971319afa3" alt=""
ElevatedButton(
onPressed: () {
print("ElevatedButton Pressed");
},
child: Text("Elevated Button"),
)
Add Styling to ElevatedButton
data:image/s3,"s3://crabby-images/0f486/0f4868be20383ab6686930ad24e45f69ed2f7268" alt=""
ElevatedButton(
style: ElevatedButton.styleFrom(
backgroundColor: Colors.blue, // Replaces `primary`
foregroundColor: Colors.white, // Replaces `onPrimary`
padding: EdgeInsets.symmetric(horizontal: 20, vertical: 10),
),
onPressed: () {},
child: Text("Styled Elevated Button"),
)
This button is used for primary actions.
TextButton
A TextButton
is a button with only text, with no shadow or background color.
data:image/s3,"s3://crabby-images/b8b6b/b8b6b57c800cc451722b80f90979be13ca86146f" alt=""
TextButton(
onPressed: () {
print(“TextButton pressed”);
},
child: Text(“TextButton”),
)
This button is typically used for secondary actions.
OutlinedButton
An OutlinedButton
has a border around it but no filled background color.
data:image/s3,"s3://crabby-images/b03df/b03df50de8783d9678226fe914264c35e397f529" alt=""
OutlinedButton(
onPressed: () {
print("OutlinedButton pressed");
},
child: Text("OutlinedButton"),
)
This button is ideal for actions that are not the primary focus.
IconButton
An IconButton
is a button with just an icon and is commonly used for icon-only actions like “delete” or “favorite.”
data:image/s3,"s3://crabby-images/874e7/874e711a9f04c8439692e3b15b88024271bf7d28" alt=""
IconButton(
icon: Icon(Icons.favorite, color: Colors.pink),
onPressed: () {
print("IconButton pressed");
},
)
This example creates a heart icon button that prints a message when pressed.
FloatingActionButton
A FloatingActionButton
(FAB) is a round button often used for primary actions on a screen, typically in a Scaffold
.
data:image/s3,"s3://crabby-images/41294/412948887276b86fc4a991521dcbd46ae18ce2f8" alt=""
FloatingActionButton(
onPressed: () {
print("FloatingActionButton pressed");
},
child: Icon(Icons.add),
),
This adds a round FAB with a “+” icon to the screen, commonly used for actions like “add.”
DropdownButton
A DropdownButton
provides a dropdown menu for selecting items from a list.
data:image/s3,"s3://crabby-images/7d00d/7d00d747d842b11bf60b5a83218051b9a1f9a2ac" alt=""
- Create a DropdownButtonWidget File
import ‘package:flutter/material.dart’;
class DropdownButtonWidget extends StatefulWidget {
@override
_DropdownButtonWidgetState createState() => _DropdownButtonWidgetState();
}
class _DropdownButtonWidgetState extends State<DropdownButtonWidget> {
String? _selectedItem;
@override
Widget build(BuildContext context) {
return DropdownButton<String>(
hint: Text(“Select an item”),
value: _selectedItem,
items: [“Item a”, “Item b”, “Item c”].map((String item) {
return DropdownMenuItem<String>(
value: item,
child: Text(item),
);
}).toList(),
onChanged: (newValue) {
setState(() {
_selectedItem = newValue;
});
},
);
}
}
2) Add this to the main.dart file
import 'package:flutter/material.dart';
import 'package:basic_widgets/dropdownButtonWidget.dart';
void main() {
runApp(const MainApp());
}
class MainApp extends StatelessWidget {
const MainApp({super.key});
@override
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
body: Center(
child: DropdownButtonWidget()
)
),
);
}
}
PopupMenuButton
A PopupMenuButton
displays a menu when pressed, usually for additional options.
data:image/s3,"s3://crabby-images/c7fd3/c7fd30e71d73266771a9998cb1f1eb091b9adfa6" alt=""
- Create a PopupMenuButtonWidget.dart file
import 'package:flutter/material.dart';
class PopupMenuButtonWidget extends StatelessWidget {
@override
Widget build(BuildContext context) {
return PopupMenuButton<String>(
onSelected: (String value) {
print("Selected: $value");
},
itemBuilder: (BuildContext context) => [
PopupMenuItem<String>(
value: "Option 1",
child: Text("Option 1"),
),
PopupMenuItem<String>(
value: "Option 2",
child: Text("Option 2"),
),
PopupMenuItem<String>(
value: "Option 3",
child: Text("Option 3"),
),
],
child: Text("PopupMenuButton (Tap to Open)"),
);
}
}
2) Add this to the main.dart file
import ‘package:basic_widgets/PopupMenuButtonWidget.dart’;
import ‘package:flutter/material.dart’;
import ‘package:basic_widgets/PopupMenuButtonWidget.dart’;
void main() {
runApp(const MainApp());
}
class MainApp extends StatelessWidget {
const MainApp({super.key});
@override
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
body: Center(
child: PopupMenuButtonWidget()
)
),
);
}
}