native_flutter_fonts

Last updated:

0 purchases

native_flutter_fonts Image
native_flutter_fonts Images
Add to Cart

Description:

native flutter fonts

native_flutter_fonts #
Provides a font registry and resolver on the native side (both Android and iOS) so that native code can resolve and use Flutter fonts.
Automatically attempts to load all fonts from the Flutter font asset manifest, and stores them in a singleton instance so that they can be accessed.
This is currently used by the following plugins:

native_tab_bar
accessible_text_view

Installation / Setup #

Add as a dependency to your plugin's or project's pubspec.yaml.
Important! Add to your plugin_name.podspec (plugin), or Podfile (app project).

Plugin plugin_name.podspec #
Pod::Spec.new do |s|
...
s.dependency 'Flutter'
s.dependency 'native_flutter_fonts' # <-- add here
...
end
copied to clipboard
App Podfile -- Do not add if your app already uses a plugin that depends on the native_flutter_fonts pod! #
...
target 'Runner' do
use_frameworks!
use_modular_headers!
...
pod 'native_flutter_fonts' # <-- add here
...
end
...
copied to clipboard
Android Usage #
Kotlin:
import com.dra11y.flutter.native_flutter_fonts.FlutterFontRegistry
...
/// If "MaterialIcons" does not exist in the manifest, returns `null`.
val iconTypeface: Typeface? = FlutterFontRegistry.resolveOrNull("MaterialIcons")

/// If "My Font Family" does not exist in the manifest, returns the default Android typeface
/// for the given weight and italic style.
val myTextTypeface: Typeface = FlutterFontRegistry.resolve("My Font Family", weight = 600, isItalic = false)
copied to clipboard
iOS Usage #
In your Swift file:
import native_flutter_fonts
...

let textFont: UIFont? = FlutterFontRegistry.resolve(family: 'Roboto', size: 14, weight: 400)

let fallbackFont: UIFont = FlutterFontRegistry.resolveOrSystemDefault(family: 'My Font', size: 14, weight: 400)
copied to clipboard
The resolve and resolveOrSystemDefault functions expect font weights in Flutter FontWeight units. These range from 100 (thin) to 400 (normal) to 900 (extra bold), in increments of 100.
However, iOS font weights (CGFloat) range from -1.0 (thin) to 0.0 (normal) to +1.0 (extra bold).
To convert between the two, we provide two convenience functions:
FlutterFontRegistry.flutterWeightFromAppleWeight(_ weight: CGFloat) -> Int

FlutterFontRegistry.appleWeightFromFlutterWeight(_ weight: Int) -> CGFloat
copied to clipboard

License:

For personal and professional use. You cannot resell or redistribute these repositories in their original state.

Files In This Product:

Customer Reviews

There are no reviews.