Font management (System & Custom) for iOS and tvOS
Usage
No more wasted time searching for names of UIFont fonts and no more surprises at runtime if a font name was mistyped.
This library is simply one extension to UIFont and one Fontenum with a case for each system font on iOS and tvOS.
Custom font support is also available, please keep reading for details!
Instead of using the String based constructor native to UIFont:
let font = UIFont(name: "Arial-BoldItalicMT", size: 12.0)
You can now simply start typing the name of the font enum and let code completion help you:
This library currently provides two different options for creating UIFont objects.
The first is calling the font name off of the provided BuiltInFont enumeration and then calling of(size:)
to provide the desired size.
let myFont: UIFont? = BuiltInFont.helvetica.of(size: 12.0)
The other UIFont creation method offered by this library is similar to the normal UIFont
constructor except that instead of providing a String of the desired font, a case of the Font enum is provided instead.
let font = UIFont(font: .arialBoldItalicMT, size: 12.0)
What about Custom Fonts?
Custom Fonts can be added with the help of the FontRepresentable protocol.
Simply create your own CustomFontString based enumeration that adapts the
FontRepresentable and add a case per font that you want to add like so:
// In your project using custom fonts
enum CustomFont: String, FontRepresentable {
case alexBrushRegular = "AlexBrush-Regular"
}
CustomFont.alexBrushRegular.of(size: 12.0) // => UIFont
SwiftUI support
SwiftUI Font is handled in a same way as UIKit UIFont.
You can do both:
let myFont: Font = BuiltInFont.helvetica.of(size: 12.0)
let font = Font(font: .arialBoldItalicMT, size: 12.0)
Installation
Carthage
If you use Carthage to manage your dependencies, simply add
UIFontComplete to your Cartfile:
github "Nirma/UIFontComplete"
If you use Carthage to build your dependencies, make sure you have added UIFontComplete.framework to the “Linked Frameworks and Libraries“ section of your target, and have included UIFontComplete.framework in your Carthage framework copying build phase.
CocoaPods
If you use CocoaPods to manage your dependencies, simply add
UIFontComplete to your Podfile:
pod 'UIFontComplete'
Swift Package Manager
In Xcode, select File > Add Packages, then copy-paste the URL for this repository to the search field and hit the “Add Package” button.
Requirements
Xcode 9.0
Swift 4.0+
Contributing to UIFontComplete
Pull Requests are Welcome!
If you feel that this library could be made better then please do so by sending over a pull request!
License
UIFontComplete is free software, and may be redistributed under the terms specified in the LICENSE file.
UIFontComplete
Font management (System & Custom) for iOS and tvOS
Usage
No more wasted time searching for names of
UIFont
fonts and no more surprises at runtime if a font name was mistyped. This library is simply one extension toUIFont
and oneFont
enum
with a case for each system font on iOS and tvOS. Custom font support is also available, please keep reading for details!Instead of using the
String
based constructor native toUIFont
:You can now simply start typing the name of the font enum and let code completion help you:
This library currently provides two different options for creating
UIFont
objects. The first is calling the font name off of the providedBuiltInFont
enumeration and then callingof(size:)
to provide the desired size.The other
UIFont
creation method offered by this library is similar to the normalUIFont
constructor except that instead of providing aString
of the desired font, a case of theFont
enum is provided instead.What about Custom Fonts?
Custom Fonts can be added with the help of the
FontRepresentable
protocol. Simply create your ownCustomFont
String
based enumeration that adapts theFontRepresentable
and add a case per font that you want to add like so:SwiftUI support
SwiftUI Font is handled in a same way as UIKit UIFont.
You can do both:
Installation
Carthage
If you use Carthage to manage your dependencies, simply add UIFontComplete to your
Cartfile
:If you use Carthage to build your dependencies, make sure you have added
UIFontComplete.framework
to the “Linked Frameworks and Libraries“ section of your target, and have includedUIFontComplete.framework
in your Carthage framework copying build phase.CocoaPods
If you use CocoaPods to manage your dependencies, simply add UIFontComplete to your
Podfile
:Swift Package Manager
In Xcode, select File > Add Packages, then copy-paste the URL for this repository to the search field and hit the “Add Package” button.
Requirements
Contributing to UIFontComplete
Pull Requests are Welcome! If you feel that this library could be made better then please do so by sending over a pull request!
License
UIFontComplete is free software, and may be redistributed under the terms specified in the LICENSE file.