iOS

preferredFont와 UIFontMetrics

Zedd0202 2021. 4. 2. 18:06
반응형

 

안녕하세요 :) Zedd입니다.

2021 제1차 정보접근성 오픈 아카데미에서 인상깊게 본 것 중 하나가 UIFontMetrics인데, 

얼른 공부해보고싶더라구요! 

 

# Dynamic Type 

사용자가 원하는 Text(Content) Size Category를 선택할 수 있도록 하는 기능.

명시적으로 Text size를 입력하는게 아니라, category를 지정하는 것. 

 

# 앱이 Dynamic Type을 지원하는 법

text에 font크기를 지정할 때, 

let label = UILabel()
label.font = UIFont.systemFont(ofSize: 16, weight: .regular)

뭐 대충 이렇게 size와 weight를 지정해줄텐데, 이렇게 하면 Dynamic Type을 지원 할 수 없다.

왜냐? 

font size를 더 키웠지만, 나는 size를 "16"으로 고정해놨기때문. 

Dynamic Type을 지원하려면 Text Style을 사용하면 된다.

[스토리보드]

기본적으로 Font에 저렇게 들어가있을텐데,

Font부분을 System에서 Text Style중 하나를 선택하게 하면 된다.

[코드]

let label = UILabel()
label.font = UIFont.preferredFont(forTextStyle: .body)

preferredFont에 원하는 Text Style을 넣어주면 된다.

 

이렇게 TextStyle만 지정하면 

이렇게 Dynamic Type을 지원하는 앱으로 변신!

 

# 설정 왔다갔다 하기 귀찮...

2가지 방법이 있다.

[1] 빌드 후 Environment Overrides 클릭

Text부분을 On하고 바꿔주면 된다. 

 

[2] Accessibility Inspector 사용 

[1]보다는 귀찮아서 이 방법은 추천하지 않는다. 하지만 알아놓으면 좋으니까!

Accessibility Inspector 사용법은 Accessibility Inspector글 참고..!! 

Font Size에서 조절하면 된다.

 

# 바로 바로 적용이 안됨.

원래 바로바로 적용이 안되는게 맞고 따로 작업을 해줘야한다.

[스토리보드]

[코드]

let label = UILabel()
label.font = UIFont.preferredFont(forTextStyle: .body)
label.adjustsFontForContentSizeCategory = true ✅

이렇게 하면 바로바로 변경이 될 것이다. 

 

이것 이외에도, 만약 설정의 Font size category가 변경될 때 마다 뭔가 해주고싶다면, 

override func traitCollectionDidChange(_ previousTraitCollection: UITraitCollection?) {
    super.traitCollectionDidChange(previousTraitCollection)
    // code
}

traitCollectionDidChange을 override하면 된다. 

여기서 Font 업데이트 시켜줘도 됨.

 

# 설정 Font size category를 얻어오고싶다.

UIApplication.shared.preferredContentSizeCategory
or
self.traitCollection.preferredContentSizeCategory

를 통해 현재 Font size category를 얻어올 수 있다. 

종류는 UIContentSizeCategory에서 확인 가능. 

왼쪽 그림처럼 기본적으로 7단계의 category가 있고, Larger Accessibility Sizes를 on하면 5단계가 더 늘어난다.

총 12단계 조절가능.

extraSmall
small
medium
large
extraLarge
extraExtraLarge
extraExtraExtraLarge

// Larger Accessibility Sizes On
accessibilityMedium
accessibilityLarge
accessibilityExtraLarge
accessibilityExtraExtraLarge
accessibilityExtraExtraExtraLarge

이름 정말...직관적..ㅎ

 

# Larger Accessibility Sizes가 On인지 Off인지?

UIApplication.shared.preferredContentSizeCategory.isAccessibilityCategory
or
self.traitCollection.preferredContentSizeCategory.isAccessibilityCategory

isAccessibilityCategory를 통해 확인이 가능하다.

 

# 각 Category를 지정했을 때 Font size가 어떻게 나오는지 궁금해

내가 TextStyle을 Body로 지정하고, extraLarge category로 지정했을 때

Font Size가 어떻게 되는지 궁금할 수 있다.

HIG > Typography에서 확인 가능.

상단 탭으로 Category를 지정하면 각 Text Style의 Font Size와 Weight을 확인할 수 있다.

 

# 나는 CustomFont로 Dynamic Type을 지원하게 하고싶어 

TextStyle을 지정하면,

그냥 이게 전부인데..Custom Font를 사용하고 싶다면 UIFontMetrics을 사용하면 된다. 

 

# UIFontMetrics

Dynamic Type을 지원하기 위해 custom font를 받을 수 있는 utility object.

1. 그냥 나는 Text Style안쓸거고, Category에 맞게 그냥 scale만 됐으면 좋겠어

let customFont = UIFont(name: "Kefa", size: 35)!
label.font = UIFontMetrics.default.scaledFont(for: customFont) ✅ 

그럴 땐 이렇게 사용하면 된다.

기본적으로 Body Text Style이 사용되므로 (From WWDC) 전부 일정하게 커진다.

 

2. 나는 TextStyle에 맞게 scale되었으면 좋겠어.

let customFont = UIFont(name: "Kefa", size: 35)!
label.font = UIFontMetrics(forTextStyle: .headline).scaledFont(for: customFont) ✅

이런식으로 textStyle을 지정해주면 된다. 

 

참고

developer.apple.com/documentation/uikit/uifont/scaling_fonts_automatically

developer.apple.com/videos/play/wwdc2017/245/

developer.apple.com/design/human-interface-guidelines/ios/visual-design/typography/

반응형