SW 개발/Kotlin

Kotlin, Apache PDFBox, TTF/OTF 글꼴 파일 메타 정보 확인하기

지단로보트 2021. 4. 8. 16:13

개요

  • 이번 글에서는 PDFBox 라이브러리를 이용하여 TTF(트루타입), OTF(오픈타입) 글꼴 파일의 메타 정보를 확인하는 방법을 소개하고자 한다.

build.gradle.kts

  • 프로젝트 루트의 build.gradle.kts 파일에 아래 내용을 추가한다.
dependencies {
    implementation("org.apache.pdfbox:pdfbox:2.0.23")
}

글꼴 파일 인식

  • 글꼴 파일을 인식하는 방법은 아래처럼 매우 간단하다.
import org.apache.fontbox.ttf.OTFParser
import org.apache.fontbox.ttf.OpenTypeFont
import org.apache.fontbox.ttf.TTFParser
import org.apache.fontbox.ttf.TrueTypeFont

// OTF 글꼴 인식, TTF 글꼴 인식도 가능
val otf: OpenTypeFont = OTFParser().parse("C:\\GothaProMedIta.otf")

// TTF 글꼴 인식, OTF 글꼴 인식은 불가능
val ttf: TrueTypeFont = TTFParser().parse("C:\\malgun.ttf")

글꼴 메타 정보 획득

  • 글꼴 파일이 정상 인식되었다면, 광범위한 메타 정보를 획득할 수 있다. 아래는 기본적인 글꼴 이름을 획득하는 예이다.
// Malgun Gothic
val englishFontFamily: String? = ttf.naming.nameRecords.firstOrNull { it.languageId == 0 && it.nameId == 1 }?.string

// Regular
val englishFontSubFamily: String? = ttf.naming.nameRecords.firstOrNull { it.languageId == 0 && it.nameId == 2 }?.string

// 맑은 고딕
val koreanFontFamily: String? = ttf.naming.nameRecords.firstOrNull { it.languageId == 1042 && it.nameId == 1 }?.string

// Regular
val koreanFontSubFamily: String? = ttf.naming.nameRecords.firstOrNull { it.languageId == 1042 && it.nameId == 2 }?.string

발생 가능한 예외

  • .parse() 실행시 발생 가능한 예외는 아래와 같다.
// 대상 파일이 존재하지 않을 경우
java.io.FileNotFoundException

// 인식 가능한 파일이 아닐 경우
java.io.EOFException
java.io.IOException