Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- Xcode
- MVVM
- swift documentation
- tableView
- Protocol
- ios
- HIG
- swiftUI
- Observable
- UICollectionView
- map
- Human interface guide
- Refactoring
- 리팩토링
- clean architecture
- uiscrollview
- ribs
- 스위프트
- rxswift
- 리펙토링
- Clean Code
- uitableview
- 리펙터링
- 애니메이션
- UITextView
- combine
- RxCocoa
- SWIFT
- collectionview
- 클린 코드
Archives
- Today
- Total
김종권의 iOS 앱 개발 알아가기
[iOS - swiftUI] Font 사용 방법 (systemFont, font weight, design, textStyle, font style, kerning, tracking) 본문
iOS 기본 (SwiftUI)
[iOS - swiftUI] Font 사용 방법 (systemFont, font weight, design, textStyle, font style, kerning, tracking)
jake-kim 2022. 8. 2. 22:50Font를 사용하기 전에, dark mode도 확인위한 preview 설정
- preview에 ColorScheme.allCases로 컬러 스킴에 접근하여 preferredColorScheme을 지정하여 dark mode도 확인할 수 있도록 설정
struct ContentView_Previews: PreviewProvider {
static var previews: some View {
ForEach(ColorScheme.allCases, id: \.self) {
ContentView().preferredColorScheme($0)
}
}
}
System Font 사용 방법
- systemFont
- .font로 Text에 적용이 가능
- systemFont는 맥에서 자주 사용되는 SF pro 폰트(=San Francisco font)를 의미
var body: some View {
VStack {
Text("Text1")
Text("Text2")
.font(.system(size: 12))
}
}
cf) Text("some text")를 사용하면 자동으로 black 컬러로 지정되고, dark mode에서는 white color로 지정
dark mode x | dark mode o |
- weight 속성
- weight는 굵기를 의미
- SwiftUI에서는 9가지의 weight를 제공
- weight를 따로 선언하지 않으면 regular 속성이 적용
dark mode x | dark mode o |
// bold
Text("bold")
.font(.system(size: 15, weight: .bold))
- design 속성
- 글자의 모양을 정의 (4가지 존재)
- 영문에만 적용
dark mode x | dark mode o |
// default
Text(".default")
.font(.system(size: 15, weight: .black, design: .default))
TextStyle
- 애플 내부적으로 Font안에 TextStyle이라는 타입을 정의하여, 그 안에 static let으로 폰트를 미리 정의해놓은 속성들
// TextStyle 예제 코드
Text(".largeTitle")
.font(.system(.largeTitle))
FontStyle
- font style
- 배경 색상 backgroundColor(_:)
- 색상 foregroundColor(_:)
- 볼드 bold()
- 기울임 italic()
- 취소선 strikethrough()
- 밑줄 underline()
- baselineOffset
ex) baselineOffset
Text("baselineOffset(0)")
.baselineOffset(0)
.background(.red)
Text("baselineOffset(10)")
.baselineOffset(10)
.background(.green)
Text("baselineOffset(-10)")
.baselineOffset(-10)
.background(.blue)
Kerning, Tracking
- kerning은 폰트 종류에 따라 달라지며, 각 폰트 특성에 따라 글자 간격이 조절
- tracking은 폰트 종류와 관계 없이 글 자 삭이의 간격을 일정하게 설정
ex) SF Pro 폰트에서는 글자 간격이 동일하게 적용
* 전체 코드: https://github.com/JK0369/ExFont
* 참고
https://developer.apple.com/documentation/swiftui/font/largetitle
https://developer.apple.com/documentation/swiftui/text/tracking(_:)
https://developer.apple.com/documentation/swiftui/text/kerning(_:)
'iOS 기본 (SwiftUI)' 카테고리의 다른 글
[iOS - swiftUI] SF Symbols(San Francisco 심볼) 사용 방법 (0) | 2022.08.04 |
---|---|
[iOS - swiftUI] Image, 원 이미지 사용 방법 (0) | 2022.08.03 |
[iOS - swiftUI] TextField ViewModifier, SecureField 사용 방법 (0) | 2022.08.01 |
[iOS - swiftUI] TextField, @FocusState, 키보드 숨기기 사용 방법 (0) | 2022.07.31 |
[iOS - swiftUI] Text, kerning, tracking, Localization, ViewModifier, Text ViewModifiers 개념 (0) | 2022.07.30 |
Comments