다운로드 가능한 글꼴 기능을 사용하면 API가 파일을 앱에 번들로 묶거나 앱에서 글꼴을 다운로드하도록 허용하는 대신 제공업체 애플리케이션에서 글꼴을 요청할 수 있습니다. 다운로드 가능한 글꼴은 AndroidX Core 라이브러리를 통해 Android API 버전 14 이상을 실행하는 기기에서 사용할 수 있습니다.
다운로드 가능한 글꼴은 다음과 같은 이점을 제공합니다.
- 앱 크기가 줄어 앱 설치 성공률이 높아집니다.
- 여러 앱에서 제공업체를 통해 동일한 글꼴을 공유할 수 있어 전반적인 시스템 상태 개선 이렇게 하면 사용자 모바일 데이터, 휴대전화 메모리, 디스크 공간을 절약할 수 있습니다. 이 모델에서는 필요할 때 네트워크를 통해 글꼴을 가져옵니다.
다운로드 가능한 글꼴은 어떻게 작동하나요?
글꼴 제공업체는 글꼴을 검색하고 로컬에서 캐시하여 다른 앱이 글꼴을 요청 및 공유할 수 있게 해주는 애플리케이션입니다. 다음 그림은 이 프로세스를 보여줍니다.
기본 사항
다운로드 가능한 글꼴 기능은 다음과 같은 방법으로 사용할 수 있으며, 자세한 내용은 이후 섹션에서 설명합니다.
Android 스튜디오 및 Google Play 서비스에서 다운로드 가능한 글꼴 사용
Android 스튜디오 3.0 이상을 사용하여 애플리케이션에서 글꼴을 다운로드하도록 설정할 수 있습니다. 다운로드 가능한 글꼴 기능을 시작하려면 Google Play 서비스의 글꼴 제공업체를 사용하세요.
- Layout Editor에서
TextView
를 선택합니다. 그런 다음 속성에서 fontFamily > More Fonts를 선택합니다. Resources 창이 표시됩니다. - Source 메뉴에서 Google Fonts를 선택합니다.
- Fonts 상자의 'Downloadable'(다운로드 가능) 영역에서 글꼴을 선택합니다.
- Create downloadable font를 선택하고 OK 클릭
Android 스튜디오는 앱에서 글꼴을 올바르게 렌더링하는 데 필요한 관련 XML 파일을 자동으로 생성합니다.
프로그래매틱 방식으로 다운로드 가능한 글꼴 사용
Android 8.0(API 수준 26)부터 AndroidX Core는 다운로드 가능한 글꼴을 완벽하게 지원합니다. AndroidX Core 라이브러리 사용에 관한 자세한 내용은 이 페이지의 다운로드 가능한 글꼴 AndroidX Core 라이브러리 섹션을 참고하세요.
프로그래매틱 방식으로 다운로드 가능한 글꼴 기능을 사용하려면 다음 두 가지 주요 클래스와 상호작용합니다.
android.graphics.fonts.FontRequest
: 이 클래스로 글꼴 요청을 만들 수 있습니다.FontsContractCompat
: 이 클래스를 사용하면 글꼴 요청에 기반하여 새로운Typeface
객체를 만들 수 있습니다.
앱은 FontsContract
API를 사용하여 글꼴 제공업체에서 글꼴을 가져옵니다. 각 제공업체는 지원하는 Android 버전 및 쿼리 언어에 관한 자체 제한사항이 있습니다. Android 버전 및 쿼리 형식에 관한 자세한 내용은 제공업체의 문서를 참고하세요.
글꼴을 다운로드하려면 다음 단계를 완료하세요.
android.graphics.fonts.FontRequest
클래스의 인스턴스를 만들어 제공업체에 글꼴을 요청합니다. 요청을 만들려면 다음 매개변수를 전달합니다.- 글꼴 제공업체 권한
- 제공업체의 ID를 확인하기 위한 글꼴 제공업체 패키지
- 글꼴의 문자열 쿼리. 쿼리 형식에 관한 자세한 내용은 Google Fonts와 같은 글꼴 제공업체의 문서를 참고하세요.
- 제공업체의 ID를 확인하는 인증서의 해시 세트 목록
Kotlin
val request = FontRequest( "com.example.fontprovider.authority", "com.example.fontprovider", "my font", certs )
자바
FontRequest request = new FontRequest("com.example.fontprovider", "com.example.fontprovider", "my font", certs);
FontsContract.FontRequestCallback
클래스의 인스턴스를 만듭니다.onTypefaceRetrieved()
메서드를 재정의하여 글꼴 요청이 완료된 것을 표시합니다. 검색된 글꼴을 매개변수로 제공합니다. 필요에 따라 이 메서드를 사용하여 글꼴을 설정할 수 있습니다. 예를 들어TextView
에서 글꼴을 설정할 수 있습니다.onTypefaceRequestFailed()
메서드를 재정의하여 글꼴 요청 프로세스의 오류에 관한 정보를 수신합니다. 오류 코드에 관한 자세한 내용은 오류 코드 상수를 참고하세요.FontsContract.requestFont()
메서드를 호출하여 글꼴 제공업체에서 글꼴을 검색합니다. 이 메서드는 글꼴이 캐시에 있는지 확인하기 위해 검사를 시작합니다. 로컬에서 글꼴을 사용할 수 없는 경우 글꼴 제공업체를 호출하고 비동기적으로 글꼴을 검색하고 결과를 콜백에 전달합니다. 다음 매개변수를 전달합니다.Context
클래스의 인스턴스android.graphics.fonts.FontRequest
클래스의 인스턴스- 글꼴 요청의 결과를 수신하는 콜백
- 스레드에서 글꼴을 가져오는 핸들러
다음 샘플 코드는 다운로드 가능한 글꼴의 전체 프로세스를 보여줍니다.
Kotlin
val request = FontRequest( "com.example.fontprovider.authority", "com.example.fontprovider", "my font", certs ) val callback = object : FontsContract.FontRequestCallback() { override fun onTypefaceRetrieved(typeface: Typeface) { // Your code to use the font goes here. ... } override fun onTypefaceRequestFailed(reason: Int) { // Your code to deal with the failure goes here. ... } } FontsContract.requestFonts(context, request, handler, null, callback)
자바
FontRequest request = new FontRequest("com.example.fontprovider.authority", "com.example.fontprovider", "my font", certs); FontsContract.FontRequestCallback callback = new FontsContract.FontRequestCallback() { @Override public void onTypefaceRetrieved(Typeface typeface) { // Your code to use the font goes here. ... } @Override public void onTypefaceRequestFailed(int reason) { // Your code to deal with the failure goes here. ... } }; FontsContract.requestFonts(context, request, handler, null, callback);
글꼴 제공업체에서 글꼴을 다운로드하는 방법에 관한 자세한 내용은 DownloadableFonts 샘플 앱을 참고하세요.
AndroidX Core에서 다운로드 가능한 글꼴 사용
AndroidX Core는 Android API 버전 14 이상을 실행하는 기기에서 다운로드 가능한 글꼴 기능을 지원합니다. androidx.core.provider
패키지에는 이전 버전과 호환되는 다운로드 가능한 글꼴 기능 지원을 구현하는 FontsContractCompat
및 FontRequest
클래스가 포함되어 있습니다. AndroidX 클래스에는 프레임워크 메서드와 유사한 메서드가 포함되어 있으며 글꼴을 다운로드하는 프로세스는 이 페이지의 다운로드 가능한 글꼴을 프로그래매틱 방식으로 사용 섹션에 설명된 프로세스와 유사합니다.
AndroidX를 사용하여 글꼴을 다운로드하려면 androidx.core.provider
패키지에서 FontsContractCompat
및 FontRequest
클래스를 가져옵니다. FontsContract
및 android.graphics.fonts.FontRequest
프레임워크 클래스가 아닌 이러한 클래스의 인스턴스를 만듭니다.
AndroidX Core 종속 항목 추가
FontsContractCompat
및 FontRequest
클래스를 사용하려면 개발 환경 내에서 앱 프로젝트의 클래스 경로 종속 항목을 수정해야 합니다.
AndroidX Core를 애플리케이션 프로젝트에 추가하려면 앱의 build.gradle
파일에 다음 종속 항목을 추가합니다.
Groovy
dependencies { ... implementation "androidx.core:core-ktx:2.2.0" }
Kotlin
dependencies { ... implementation("androidx.core:core-ktx:2.2.0") }
다운로드 가능한 글꼴을 XML의 리소스로 사용
Android 8.0(API 수준 26) 및 AndroidX Core는 맞춤 글꼴을 XML 레이아웃에서 리소스로 선언하는 더 빠르고 편리한 방법을 제공합니다. 즉, 글꼴을 애셋으로 번들할 필요가 없습니다. 전체 테마에 맞춤 글꼴을 정의하여 굵게, 보통, 연하게 등 여러 두께 및 스타일의 사용성을 촉진할 수 있습니다.
- 새로운 XML 파일을
res/font
폴더에 만듭니다. - 다음 샘플 XML 파일과 같이
<font-family>
루트 요소를 추가하고 글꼴 관련 속성을 설정합니다. - 레이아웃 XML 파일에서
@font/font_file_name
로 파일을 참조합니다.getFont()
메서드를 사용하여 프로그래매틱 방식으로 파일을 검색할 수도 있습니다(예:getFont(R.font.font_file_name)
).
<?xml version="1.0" encoding="utf-8"?> <font-family xmlns:android="http://schemas.android.com/apk/res/android" android:fontProviderAuthority="com.example.fontprovider.authority" android:fontProviderPackage="com.example.fontprovider" android:fontProviderQuery="example font" android:fontProviderCerts="@array/certs"> </font-family>
매니페스트에서 글꼴 미리 선언
레이아웃 인플레이션 및 리소스 검색은 동기 작업입니다. 기본적으로 글꼴 검색을 위한 첫 번째 시도는 글꼴 제공업체 요청을 트리거하므로 첫 번째 레이아웃 시간이 늘어납니다. 지연을 방지하려면 매니페스트에서 검색이 필요한 글꼴을 미리 선언하면 됩니다. 시스템이 제공업체에서 글꼴을 검색하고 나면 글꼴을 즉시 사용할 수 있습니다. 글꼴 검색이 예상보다 오래 걸리면 시스템에서 가져오기 프로세스를 취소하고 기본 글꼴을 사용합니다.
매니페스트에서 글꼴을 미리 선언하려면 다음 단계를 완료하세요.
res/values/arrays.xml
에서 리소스 배열을 만들고 미리 가져오려는 글꼴을 선언합니다.meta-data
태그를 사용하여 매니페스트에서 리소스 배열을 선언합니다.
res/values/arrays.xml <?xml version="1.0" encoding="utf-8"?> <resources> <array name="preloaded_fonts"> <item>@font/font1</item> <item>@font/font2</item> </array> </resources>
<meta-data android:name="preloaded_fonts" android:resource="@array/preloaded_fonts" />
인증서 추가
글꼴 제공업체가 사전 설치되어 있지 않거나 AndroidX Core 라이브러리를 사용하는 경우 글꼴 제공업체가 서명한 인증서를 선언합니다. 시스템은 인증서를 사용하여 글꼴 제공업체의 ID를 확인합니다.
인증서를 추가하려면 다음 단계를 따르세요.
- 인증서 세부정보가 있는 문자열 배열을 만듭니다. 인증서 세부정보에 관한 자세한 내용은 글꼴 제공업체의 문서를 참고하세요.
fontProviderCerts
속성을 배열로 설정합니다.
<?xml version="1.0" encoding="utf-8"?> <resources> <string-array name="certs"> <item>MIIEqDCCA5CgAwIBAgIJA071MA0GCSqGSIb3DQEBBAUAMIGUMQsww...</item> </string-array> </resources>
android:fontProviderCerts="@array/certs"