Android 8.0 (API cấp 26) ra mắt phông chữ ở định dạng XML, một tính năng giúp
cho phép bạn dùng phông chữ làm tài nguyên. Bạn có thể thêm tệp font
trong thư mục res/font/
để nhóm các phông chữ dưới dạng tài nguyên. Các phông chữ này được tổng hợp trong tệp R
và sẽ tự động xuất hiện trong Android Studio. Bạn có thể truy cập vào các tài nguyên phông chữ bằng loại tài nguyên font
. Cho
ví dụ: để truy cập vào tài nguyên phông chữ,
hãy sử dụng @font/myfont
hoặc R.font.myfont
.
Để sử dụng tính năng phông chữ trong XML trên các thiết bị chạy Android 4.1 (API cấp 16) trở lên, hãy dùng Thư viện hỗ trợ 26.0. Thông tin khác về cách sử dụng Thư viện hỗ trợ, hãy tham khảo Sử dụng phần Thư viện hỗ trợ.
Để thêm phông chữ làm tài nguyên, hãy thực hiện các bước sau trong Android Studio:
- Nhấp chuột phải vào thư mục res rồi chuyển đến New (Mới) > Android resource directory (Thư mục tài nguyên Android). Chiến lược phát hành đĩa đơn Cửa sổ New Resource Directory (Thư mục tài nguyên mới) sẽ xuất hiện.
- Trong danh sách Resource type (Loại tài nguyên), hãy chọn font (phông chữ), rồi nhấp vào
OK.
Lưu ý: Tên của thư mục tài nguyên phải là font.
- Thêm các tệp phông chữ vào thư mục
font
.Cấu trúc thư mục bên dưới tạo ra
R.font.dancing_script
,R.font.lobster
vàR.font.typo_graphica
. - Nhấp đúp vào một tệp phông chữ để xem trước phông chữ của tệp đó trong trình chỉnh sửa.
Tạo bộ phông chữ
Bộ phông chữ là một tập hợp các tệp phông chữ cùng với thông tin về kiểu và độ đậm. Trong Android, bạn có thể tạo bộ phông chữ mới dưới dạng tài nguyên XML rồi truy cập tài nguyên đó dưới dạng một đơn vị duy nhất, thay vì tham chiếu từng kiểu và độ đậm dưới dạng các tài nguyên riêng biệt. Khi làm như vậy, bạn sẽ cho phép hệ thống chọn phông chữ chính xác dựa trên kiểu văn bản bạn đang sử dụng.
Để tạo một bộ phông chữ, hãy thực hiện các bước sau trong Android Studio:
- Nhấp chuột phải vào thư mục
font
rồi chọn Mới > Tệp tài nguyên phông chữ. Cửa sổ New Resource File (Tệp tài nguyên mới) sẽ xuất hiện. - Nhập tên tệp, rồi nhấp vào OK. XML của tài nguyên phông chữ mới sẽ mở ra trong trình chỉnh sửa.
- Đính kèm từng thuộc tính tệp phông chữ, kiểu và độ đậm trong phần tử
<font>
. XML sau đây minh hoạ cách thêm các thuộc tính liên quan đến phông chữ trong XML của tài nguyên phông chữ:<?xml version="1.0" encoding="utf-8"?> <font-family xmlns:android="http://schemas.android.com/apk/res/android"> <font android:fontStyle="normal" android:fontWeight="400" android:font="@font/lobster_regular" /> <font android:fontStyle="italic" android:fontWeight="400" android:font="@font/lobster_italic" /> </font-family>
Dùng phông chữ trong bố cục XML
Sử dụng phông chữ của bạn, có thể là một tệp phông chữ hoặc phông chữ trên
bộ phông chữ, trong TextView
hoặc theo kiểu bằng cách sử dụng
Thuộc tính fontFamily
.
Lưu ý: Khi bạn dùng bộ phông chữ, TextView
sẽ tự bật (nếu cần) để dùng các tệp phông chữ của bộ đó.
Thêm phông chữ vào TextView
Để đặt phông chữ cho TextView
, hãy thực hiện một trong
sau:
- Trong tệp XML của bố cục, hãy đặt thuộc tính
fontFamily
thành tệp phông chữ mà bạn muốn truy cập.<TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:fontFamily="@font/lobster"/>
- Mở cửa sổ Properties (Thuộc tính) để đặt phông chữ cho
TextView
.- Chọn một chế độ xem để mở cửa sổ Properties (Thuộc tính).
Lưu ý: Bạn chỉ dùng được cửa sổ Properties (Thuộc tính) khi trình chỉnh sửa thiết kế đang mở. Chọn thẻ Design (Thiết kế) ở dưới cùng của cửa sổ.
- Mở rộng thuộc tính textAppearance rồi chọn phông chữ trong danh sách fontFamily.
- Chọn một chế độ xem để mở cửa sổ Properties (Thuộc tính).
Bản xem trước bố cục của Android Studio, như trong ngăn ngoài cùng bên phải trong Hình 5,
cho phép bạn xem trước phông chữ được đặt trong TextView
.
Thêm phông chữ vào kiểu
Mở tệp styles.xml
và đặt fontFamily
cho tệp phông chữ mà bạn muốn truy cập.
<style name="customfontstyle" parent="@android:style/TextAppearance.Small"> <item name="android:fontFamily">@font/lobster</item> </style>
Dùng phông chữ theo phương thức lập trình
Để truy xuất phông chữ theo phương thức lập trình, hãy gọi phương thức getFont(int)
rồi cung cấp giá trị nhận dạng tài nguyên của phông chữ bạn muốn truy xuất. Phương thức này trả về một đối tượng Typeface
. Mặc dù hệ thống chọn công cụ tốt nhất
kiểu cho bạn dựa trên phông chữ. , bạn có thể sử dụng
setTypeface(android.graphics.Typeface, int)
để đặt kiểu chữ với các kiểu cụ thể.
Lưu ý: TextView
làm việc này cho bạn.
Kotlin
val typeface = resources.getFont(R.font.myfont) textView.typeface = typeface
Java
Typeface typeface = getResources().getFont(R.font.myfont); textView.setTypeface(typeface);
Sử dụng Thư viện hỗ trợ
Thư viện hỗ trợ 26.0 hỗ trợ phông chữ ở định dạng XML trên thiết bị chạy Android 4.1 (API cấp 16) trở lên.
Lưu ý: Khi bạn khai báo bộ phông chữ trong bố cục XML thông qua Thư viện hỗ trợ, sử dụng không gian tên app (ứng dụng) để đảm bảo rằng phông chữ của bạn tải được.
<?xml version="1.0" encoding="utf-8"?> <font-family xmlns:app="http://schemas.android.com/apk/res-auto"> <font app:fontStyle="normal" app:fontWeight="400" app:font="@font/myfont-Regular"/> <font app:fontStyle="italic" app:fontWeight="400" app:font="@font/myfont-Italic" /> </font-family>
Để truy xuất phông chữ theo phương thức lập trình, hãy gọi hàm
ResourceCompat.getFont(Context, int)
và cung cấp một
thực thể của Context
và giá trị nhận dạng tài nguyên.
Kotlin
val typeface = ResourcesCompat.getFont(context, R.font.myfont)
Java
Typeface typeface = ResourcesCompat.getFont(context, R.font.myfont);