다운로드 가능한 글꼴 사용

Compose 방식 사용해 보기
Jetpack Compose는 Android를 위한 권장 UI 도구 키트입니다. Compose에서 텍스트를 사용하는 방법을 알아보세요.

다운로드 가능한 글꼴 기능을 사용하면 API가 파일을 앱에 번들로 묶거나 앱에서 글꼴을 다운로드하도록 허용하는 대신 제공업체 애플리케이션에서 글꼴을 요청할 수 있습니다. 다운로드 가능한 글꼴은 AndroidX 핵심 라이브러리를 통해 Android API 버전 14 이상을 실행하는 기기에서 사용할 수 있습니다.

다운로드 가능한 글꼴은 다음과 같은 이점을 제공합니다.

  • 앱 크기가 줄어들어 앱 설치 성공률이 증가합니다.
  • 여러 앱이 제공자를 통해 동일한 글꼴을 공유할 수 있으므로 전반적인 시스템 상태가 개선됩니다. 이렇게 하면 사용자의 모바일 데이터, 휴대전화 메모리, 디스크 공간이 절약됩니다. 이 모델에서는 필요할 때 네트워크를 통해 글꼴을 가져옵니다.
다운로드 가능한 글꼴을 직접 사용해 보려면 DownloadableFonts 샘플 앱을 참고하세요.

다운로드 가능한 글꼴은 어떻게 작동하나요?

글꼴 제공업체는 글꼴을 검색하고 로컬에서 캐시하여 다른 앱이 글꼴을 요청 및 공유할 수 있게 해주는 애플리케이션입니다. 다음 그림은 이 프로세스를 보여줍니다.

그림 이모티콘 호환성 프로세스의 기본 구성요소를 보여주는 이미지
그림 1. 다운로드 가능한 글꼴 프로세스

기본 사항

다운로드 가능한 글꼴 기능은 다음과 같은 방법으로 사용할 수 있습니다. 이에 대해서는 이후 섹션에서 자세히 설명합니다.

Android 스튜디오 및 Google Play 서비스에서 다운로드 가능한 글꼴 사용

Android 스튜디오 3.0 이상을 사용하여 애플리케이션에서 글꼴을 다운로드하도록 설정할 수 있습니다. 다운로드 가능한 글꼴 기능을 시작하려면 Google Play 서비스의 글꼴 제공업체를 사용해 보세요.

  1. Layout Editor에서 TextView를 선택합니다. 그런 다음 Attributes에서 fontFamily > More Fonts를 선택합니다.
    Android 스튜디오 Layout Editor를 보여주는 이미지
    그림 2. Layout Editor 사용
    리소스 창이 표시됩니다.
  2. Source 메뉴에서 Google Fonts를 선택합니다.
  3. Fonts 상자의 'Downloadable'(다운로드 가능) 영역에서 글꼴을 선택합니다.
  4. Create downloadable font를 선택하고 OK 클릭
    리소스 창에서 글꼴을 선택하는 방법을 보여주는 이미지
    그림 3. 리소스 창에서 글꼴을 선택합니다.
  5. Android 스튜디오는 앱에서 글꼴을 올바르게 렌더링하는 데 필요한 관련 XML 파일을 자동으로 생성합니다.

    글꼴을 미리 보는 방법을 보여주는 이미지
    그림 4. 글꼴 파일 미리보기

프로그래매틱 방식으로 다운로드 가능한 글꼴 사용

Android 8.0(API 수준 26)부터 AndroidX Core는 다운로드 가능한 글꼴을 완벽하게 지원합니다. AndroidX Core 라이브러리 사용에 관한 자세한 내용은 이 페이지의 다운로드 가능한 글꼴 AndroidX Core 라이브러리 섹션을 참고하세요.

프로그래매틱 방식으로 다운로드 가능한 글꼴 기능을 사용하려면 다음 두 가지 주요 클래스와 상호작용합니다.

앱은 FontsContract API를 사용하여 글꼴 제공업체에서 글꼴을 가져옵니다. 각 제공업체는 지원하는 Android 버전 및 쿼리 언어에 관한 자체 제한사항이 있습니다. Android 버전 및 쿼리 형식에 관한 자세한 내용은 제공업체의 문서를 참고하세요.

글꼴을 다운로드하려면 다음 단계를 완료하세요.

  1. 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);
  2. FontsContract.FontRequestCallback 클래스의 인스턴스를 만듭니다.
  3. onTypefaceRetrieved() 메서드를 재정의하여 글꼴 요청이 완료된 것을 표시합니다. 검색된 글꼴을 매개변수로 제공합니다. 이 메서드를 사용하여 필요에 따라 글꼴을 설정할 수 있습니다. 예를 들어 TextView에서 글꼴을 설정할 수 있습니다.
  4. onTypefaceRequestFailed() 메서드를 재정의하여 글꼴 요청 프로세스의 오류에 관한 정보를 수신합니다. 오류 코드에 관한 자세한 내용은 오류 코드 상수를 참고하세요.
  5. 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 패키지에는 이전 버전과 호환되는 다운로드 가능한 글꼴 기능 지원을 구현하는 FontsContractCompatFontRequest 클래스가 포함되어 있습니다. AndroidX 클래스에는 프레임워크 메서드와 유사한 메서드가 포함되어 있으며 글꼴을 다운로드하는 프로세스는 이 페이지의 다운로드 가능한 글꼴을 프로그래매틱 방식으로 사용 섹션에 설명된 프로세스와 유사합니다.

AndroidX를 사용하여 글꼴을 다운로드하려면 androidx.core.provider 패키지에서 FontsContractCompatFontRequest 클래스를 가져옵니다. FontsContractandroid.graphics.fonts.FontRequest 프레임워크 클래스가 아닌 이러한 클래스의 인스턴스를 만듭니다.

AndroidX Core 종속 항목 추가

FontsContractCompatFontRequest 클래스를 사용하려면 개발 환경 내에서 앱 프로젝트의 클래스 경로 종속 항목을 수정해야 합니다.

애플리케이션 프로젝트에 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 레이아웃에서 리소스로 선언하는 더 빠르고 편리한 방법을 제공합니다. 즉, 글꼴을 애셋으로 번들할 필요가 없습니다. 전체 테마에 맞춤 글꼴을 정의하여 굵게, 보통, 연하게 등 여러 두께 및 스타일의 사용성을 촉진할 수 있습니다.

  1. 새로운 XML 파일을 res/font 폴더에 만듭니다.
  2. 다음 샘플 XML 파일과 같이 <font-family> 루트 요소를 추가하고 글꼴 관련 속성을 설정합니다.
  3. <?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>
  4. 레이아웃 XML 파일에서 @font/font_file_name로 파일을 참조합니다. getFont() 메서드를 사용하여 프로그래매틱 방식으로 파일을 검색할 수도 있습니다(예: getFont(R.font.font_file_name)).

매니페스트에서 글꼴 미리 선언

레이아웃 인플레이션 및 리소스 검색은 동기 작업입니다. 기본적으로 글꼴 검색을 위한 첫 번째 시도는 글꼴 제공업체 요청을 트리거하므로 첫 번째 레이아웃 시간이 늘어납니다. 지연을 방지하려면 매니페스트에서 검색이 필요한 글꼴을 미리 선언하면 됩니다. 시스템이 제공업체에서 글꼴을 검색하고 나면 글꼴을 즉시 사용할 수 있습니다. 글꼴 검색이 예상보다 오래 걸리면 시스템에서 가져오기 프로세스를 취소하고 기본 글꼴을 사용합니다.

매니페스트에서 글꼴을 미리 선언하려면 다음 단계를 완료하세요.

  1. res/values/arrays.xml에서 리소스 배열을 만들고 미리 가져오려는 글꼴을 선언합니다.
  2. 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>
  3. meta-data 태그를 사용하여 매니페스트에서 리소스 배열을 선언합니다.
  4. <meta-data android:name="preloaded_fonts" android:resource="@array/preloaded_fonts" />

인증서 추가

글꼴 제공업체가 사전 설치되어 있지 않거나 AndroidX Core 라이브러리를 사용하는 경우 글꼴 제공업체가 서명한 인증서를 선언합니다. 시스템은 인증서를 사용하여 글꼴 제공업체의 ID를 확인합니다.

인증서를 추가하려면 다음 단계를 따르세요.

  1. 인증서 세부정보가 있는 문자열 배열을 만듭니다. 인증서 세부정보에 관한 자세한 내용은 글꼴 제공업체의 문서를 참고하세요.
  2. <?xml version="1.0" encoding="utf-8"?>
    <resources>
        <string-array name="certs">
           <item>MIIEqDCCA5CgAwIBAgIJA071MA0GCSqGSIb3DQEBBAUAMIGUMQsww...</item>
        </string-array>
    </resources>
  3. fontProviderCerts 속성을 배열로 설정합니다.
  4. android:fontProviderCerts="@array/certs"

Compose의 다운로드 가능한 글꼴