A Flutter package to use fonts from fonts.google.com.
For example, say you want to use the Lato font from Google Fonts in your Flutter app.
google_fonts
package to your pubspec dependencies.To use GoogleFonts
with the default TextStyle
:
Text('This is Google Fonts', style: GoogleFonts.lato()),
Or, if you want to load the font dynamically:
Text('This is Google Fonts', style: GoogleFonts.getFont('Lato')),
To use GoogleFonts
with an existing TextStyle
:
Text( 'This is Google Fonts', style: GoogleFonts.lato( textStyle: const TextStyle(color: Colors.blue, letterSpacing: .5), ), ),
or
Text( 'This is Google Fonts', style: GoogleFonts.lato( textStyle: Theme.of(context).textTheme.headlineMedium, ), ),
To override the fontSize
, fontWeight
, or fontStyle
:
Text( 'This is Google Fonts', style: GoogleFonts.lato( textStyle: Theme.of(context).textTheme.displayLarge, fontSize: 48, fontWeight: FontWeight.w700, fontStyle: FontStyle.italic, ), ),
You can also use GoogleFonts.latoTextTheme()
to make or modify an entire text theme to use the “Lato” font.
class MyApp extends StatelessWidget { // ··· @override Widget build(BuildContext context) { return MaterialApp( // ··· theme: _buildTheme(Brightness.dark), // ··· ); } } ThemeData _buildTheme(Brightness brightness) { final ThemeData baseTheme = ThemeData(brightness: brightness); return baseTheme.copyWith( textTheme: GoogleFonts.latoTextTheme(baseTheme.textTheme), ); }
Or, if you want a TextTheme
where a couple of styles should use a different font:
final TextTheme textTheme = Theme.of(context).textTheme; return MaterialApp( // ··· theme: ThemeData( textTheme: GoogleFonts.latoTextTheme(textTheme).copyWith( bodyMedium: GoogleFonts.oswald(textStyle: textTheme.bodyMedium), ), ), // ··· );
To avoid visual font swaps that occur when a font is loading, use FutureBuilder and GoogleFonts.pendingFonts().
See the example app.
For HTTP fetching to work, certain platforms require additional steps when running the app in debug and/or release mode. For example, macOS requires the following be present in the relevant .entitlements file:
<key>com.apple.security.network.client</key> <true/>
Learn more at https://docs.flutter.dev/development/data-and-backend/networking#platform-notes.
The google_fonts
package will automatically use matching font files in your pubspec.yaml
‘s assets
(rather than fetching them at runtime via HTTP). Once you’ve settled on the fonts you want to use:
Italic
in the filename. Font weights map to file names as follows:<FontWeight, String>{ FontWeight.w100: 'Thin', FontWeight.w200: 'ExtraLight', FontWeight.w300: 'Light', FontWeight.w400: 'Regular', FontWeight.w500: 'Medium', FontWeight.w600: 'SemiBold', FontWeight.w700: 'Bold', FontWeight.w800: 'ExtraBold', FontWeight.w900: 'Black', };
google_fonts
). You can name this folder whatever you like and use subdirectories.google_fonts/
) in your pubspec.yaml
, under assets
.Note: Since these files are listed as assets, there is no need to list them in the fonts
section of the pubspec.yaml
. This can be done because the files are consistently named from the Google Fonts API (so be sure not to rename them!)
See the API docs to completely disable HTTP fetching.
The fonts on fonts.google.com include license files for each font. For example, the Lato font comes with an OFL.txt
file.
Once you‘ve decided on the fonts you want in your published app, you should add the appropriate licenses to your flutter app’s LicenseRegistry.
For example:
void main() { LicenseRegistry.addLicense(() async* { final String license = await rootBundle.loadString('google_fonts/OFL.txt'); yield LicenseEntryWithLineBreaks(<String>['google_fonts'], license); }); runApp(const MyApp()); }
See example/test for testing examples.