The Material Design Icons (https://materialdesignicons.com/) Icon pack available as set of Flutter Icons.
The Material Design Icons Icon pack available as set of Flutter Icons.
Based on Material Design Icons 5.8.55. 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: 4.0.5855
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.yamlis 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
fromStringmethod 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
fromStringwork we need a map for all icon names. Using this method will not get the benifits of tree-shaking.
On flutter 1.22 and above, using
fromStringmethod 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