The Material Design Icons Icon pack available as set of Flutter Icons.
Based on Material Design Icons 7.4.47. See a web demo build with this package.
👍 Like us on pub.dev!
In the dependencies:
section of your pubspec.yaml
, add the following line:
material_design_icons_flutter: 7.0.7447
WARNING: MDI's version is based on their icons quantity, which does not strictly respect semver guide. They do try their best to keep icons in same name between minor releases but name changing may still appear. To not break your application, using a fix version in your pubspec.yaml
is highly recommended.
import 'package:material_design_icons_flutter/material_design_icons_flutter.dart';
class MyWidget extends StatelessWidget {
Widget build(BuildContext context) {
return new IconButton(
// Use the MdiIcons class for the IconData
icon: new Icon(MdiIcons.sword),
onPressed: () { print('Using the sword'); }
);
}
}
Or, if you want to access the icon by a string name, you can use fromString
method to create one.
import 'package:material_design_icons_flutter/material_design_icons_flutter.dart';
class MyWidget extends StatelessWidget {
Widget build(BuildContext context) {
return new IconButton(
// Use the string name to access icons.
icon: new Icon(MdiIcons.fromString('sword')),
onPressed: () { print('Using the sword'); }
);
}
}
Note: This is not recomended because to make fromString
work we need a map for all icon names. Using this method will not get the benefits of tree-shaking.
On flutter 1.22 and above, using fromString
method will also cause a compile error This application cannot tree shake icons fonts
, which can be bypass by building with --no-tree-shake-icons
.
Some icons' names are reserved keywords in Dart (and most other languages), so they have been changed.
null
-> nullIcon
switch
-> switchIcon
sync
-> syncIcon
factory
-> factoryIcon