Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hemantasapkota/opensansswift
Easily use the OpenSans font in Swift
https://github.com/hemantasapkota/opensansswift
carthage opensans opensans-font swift
Last synced: 16 days ago
JSON representation
Easily use the OpenSans font in Swift
- Host: GitHub
- URL: https://github.com/hemantasapkota/opensansswift
- Owner: hemantasapkota
- License: mit
- Created: 2015-02-17T06:30:38.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2017-11-06T23:03:17.000Z (about 7 years ago)
- Last Synced: 2024-10-12T07:13:54.801Z (about 1 month ago)
- Topics: carthage, opensans, opensans-font, swift
- Language: Swift
- Size: 1020 KB
- Stars: 41
- Watchers: 7
- Forks: 7
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
[![Carthage compatible](https://img.shields.io/badge/Carthage-compatible-4BC51D.svg?style=flat)](https://github.com/Carthage/Carthage)
## OpenSansSwift ##
Easily use the OpenSans font in Swift.![Screenshot](OpenSans-SS.png)
## Why use OpenSansSwift frameworks ? ##
The usual process of embedding any custom fonts in your IOS applications has a few steps:
1. Copy all your font resources to your project
2. Make sure they're copied to the bundle
3. Add UIAppFonts key to info.plist.
4. Painstakingly add all the font names with the right extension
5. Find out the font family and font names programatically
6. Use the fontsFor the OpenSans font, this framework does all that for you. All you have to do is link the compiled framework.
## How to Install - Carthage ##
If you dont' already have Carthage, Install it with:
```
$ brew update
$ brew install carthage
```Add ```github "hemantasapkota/OpenSansSwift"``` to your Cartfile.
Execute ```carthage install```
## Swift 3 ##
Add ```github "hemantasapkota/OpenSansSwift" "swift3"``` to your Cartfile.
Execute ```carthage install```
## How to Install - Manual ##
Clone the repo and add ```OpenSansSwift.xcodeproj``` to you project. Link ```OpenSansSwift.framework``` to your project.
## OpenSans Font Methods ##
Based on *OpenSans v2.0*, *OpenSansSwift* registers the following methods:
```
openSansFontOfSize(size: Float) -> UIFont!
openSansBoldFontOfSize(size: Float) -> UIFont!
openSansBoldItalicFontOfSize(size: Float) -> UIFont!
openSansExtraBoldFontOfSize(size: Float) -> UIFont!
openSansExtraBoldItalicFontOfSize(size: Float) -> UIFont!
openSansItalicFontOfSize(size: Float) -> UIFont!
openSansLightFontOfSize(size: Float) -> UIFont!
openSansLightItalicFontOfSize(size: Float) -> UIFont!
openSansSemiboldFontOfSize(size: Float) -> UIFont!
openSansSemiboldItalicFontOfSize(size: Float) -> UIFont!
```## Retina Scale Factor ##
Set ```OpenSans.retinaScaleFactor``` to scale out font sizes for the iPad. Default is 2.## Usage - Programmatically ##
See Example for more details.
```
import UIKit
import OpenSansSwiftclass ViewController: UIViewController {
override func viewDidLoad() {
super.viewDidLoad()
//Register Open Sans fonts. Register only once.
OpenSans.registerFonts()
// Set the scale for iPad. Default is 2.
OpenSans.retinaScaleFactor = 1.5
// Create a label
let lbl1 = UILabel(frame: CGRectMake(x, y, size.width, size.height))
lbl1.font = UIFont.openSansFontOfSize(30)
lbl1.text = "This is OpenSans-Regular"
self.view.addSubView(lbl1)
}
}
```## Usage - Storyboard ##
XCode automatically detects the fonts present in the bundle, so you don't have to perform any registration for use in Storyboards.
![Screenshot](OpenSans-StoryBoard.png)
## Usage - With NSAttributedString ##
For use with NSAttributedString, Use the following strings: OpenSans, OpenSans-Bold, OpenSans-Italic
```
let regularAttribute = [NSFontAttributeName: UIFont(name: "OpenSans", size: 12)!]
let boldAttribute = [NSFontAttributeName: UIFont(name: "OpenSans-Bold", size: 12)!]
let italicAttribute = [NSFontAttributeName: UIFont(name: "OpenSans-Italic", size: 12)!]
```## Licence ##
* MIT for OpenSansSwift framework.
* Apache for OpenSans v2.0 fonts. See http://www.apache.org/licenses/