Deskripsi
Gunakan chrome.fontSettings
API untuk mengelola setelan font Chrome.
Izin
fontSettings
Untuk menggunakan Font Settings API, Anda harus mendeklarasikan izin "fontSettings"
dalam manifes
ekstensi. Contoh:
{
"name": "My Font Settings Extension",
"description": "Customize your fonts",
"version": "0.2",
"permissions": [
"fontSettings"
],
...
}
Konsep dan penggunaan
Chrome memungkinkan beberapa setelan font bergantung pada jenis font umum dan skrip bahasa tertentu. Misalnya, font yang digunakan untuk Aksara Sederhana China sans-serif mungkin berbeda dengan font yang digunakan untuk Aksara Jepang serif.
Jenis font umum yang didukung oleh Chrome didasarkan pada jenis font umum CSS dan
tercantum di bagian GenericReference
. Saat halaman web menentukan jenis font generik, Chrome akan memilih font berdasarkan setelan yang sesuai. Jika tidak ada jenis font generik yang ditentukan, Chrome akan menggunakan
setelan untuk jenis font generik "standar".
Saat halaman web menentukan bahasa, Chrome akan memilih font berdasarkan setelan untuk skrip bahasa yang sesuai. Jika tidak ada bahasa yang ditentukan, Chrome akan menggunakan setelan untuk skrip default, atau global.
Skrip bahasa yang didukung ditentukan oleh kode skrip ISO 15924 dan tercantum di bagian
ScriptCode
. Secara teknis, setelan Chrome tidak sepenuhnya per skrip, tetapi juga bergantung pada
bahasa. Misalnya, Chrome memilih font untuk Cyrillic (kode skrip ISO 15924 "Cyrl") saat
halaman web menentukan bahasa Rusia, dan menggunakan font ini tidak hanya untuk skrip Cyrillic, tetapi untuk
semua yang dicakup font, seperti Latin.
Contoh
Kode berikut mendapatkan font standar untuk bahasa Arab.
chrome.fontSettings.getFont(
{ genericFamily: 'standard', script: 'Arab' },
function(details) { console.log(details.fontId); }
);
Cuplikan berikutnya menetapkan font sans-serif untuk bahasa Jepang.
chrome.fontSettings.setFont(
{ genericFamily: 'sansserif', script: 'Jpan', fontId: 'MS PGothic' }
);
Untuk mencoba API ini, instal contoh fontSettings API dari repositori chrome-extension-samples.
Jenis
FontName
Merepresentasikan nama font.
Properti
-
Nama Tampilan
string
Nama tampilan font.
-
fontId
string
ID font.
GenericFamily
Jenis font umum CSS.
Enum
"standard"
"sansserif"
"serif"
"fixed"
"cursive"
"fantasy"
"math"
LevelOfControl
Salah satu dari
not\_controllable
: tidak dapat dikontrol oleh ekstensi apa pun
controlled\_by\_other\_extensions
: dikontrol oleh ekstensi dengan prioritas lebih tinggi
controllable\_by\_this\_extension
: dapat dikontrol oleh ekstensi ini
controlled\_by\_this\_extension
: dikontrol oleh ekstensi ini
Enum
"not_controllable"
"controlled_by_other_extensions"
"controllable_by_this_extension"
"controlled_by_this_extension"
ScriptCode
Kode skrip ISO 15924. Skrip default, atau global, diwakili oleh kode skrip "Zyyy".
Enum
"Afak"
"Arab"
"Armi"
"Armn"
"Avst"
"Bali"
"Bamu"
"Bass"
"Batk"
"Beng"
"Blis"
"Bopo"
"Brah"
"Brai"
"Bugi"
"Buhd"
"Cakm"
"Kaleng"
"Cari"
"Cham"
"Cher"
"Cirt"
"Copt"
"Cprt"
"Cyrl"
"Cyrs"
"Deva"
"Dsrt"
"Dupl"
"Egyd"
"Egyh"
"Egyp"
"Elba"
"Ethi"
"Geor"
"Geok"
"Glag"
"Goth"
"Gran"
"Grek"
"Gujr"
"Guru"
"Hang"
"Hani"
"Hano"
"Hans"
"Hant"
"Hebr"
"Hluw"
"Hmng"
"Hung"
"Inds"
"Ital"
"Java"
"Jpan"
"Jurc"
"Kali"
"Khar"
"Khmr"
"Khoj"
"Knda"
"Kpel"
"Kthi"
"Lana"
"Laoo"
"Latf"
"Latg"
"Latn"
"Lepc"
"Limb"
"Lina"
"Linb"
"Lisu"
"Loma"
"Lyci"
"Lydi"
"Mand"
"Mani"
"Maya"
"Perbaiki"
"Merc"
"Mero"
"Mlym"
"Bulan"
"Mong"
"Mroo"
"Mtei"
"Mymr"
"Narb"
"Nbat"
"Nkgb"
"Nkoo"
"Nshu"
"Ogam"
"Olck"
"Orkh"
"Orya"
"Osma"
"Palm"
"Perm"
"Phag"
"Phli"
"Phlp"
"Phlv"
"Phnx"
"Plrd"
"Prti"
"Rjng"
"Roro"
"Runr"
"Samr"
"Sara"
"Sarb"
"Saur"
"Sgnw"
"Shaw"
"Shrd"
"Sind"
"Sinh"
"Sora"
"Sund"
"Sylo"
"Syrc"
"Syre"
"Syrj"
"Syrn"
"Tagb"
"Takr"
"Tale"
"Talu"
"Taml"
"Tang"
"Tavt"
"Telu"
"Teng"
"Tfng"
"Tglg"
"Thaa"
"Thai"
"Tibt"
"Tirh"
"Ugar"
"Vaii"
"Visp"
"Wara"
"Wole"
"Xpeo"
"Xsux"
"Yiii"
"Zmth"
"Zsym"
"Zyyy"
Metode
clearDefaultFixedFontSize()
chrome.fontSettings.clearDefaultFixedFontSize(
details?: object,
callback?: function,
)
Menghapus ukuran font tetap default yang ditetapkan oleh ekstensi ini, jika ada.
Parameter
-
detail
objek opsional
Parameter ini saat ini tidak digunakan.
-
callback
fungsi opsional
Parameter
callback
terlihat seperti:() => void
Hasil
-
Promise<void>
Chrome 96+Promise didukung di Manifes V3 dan yang lebih baru, tetapi callback disediakan untuk kompatibilitas mundur. Anda tidak dapat menggunakan keduanya pada panggilan fungsi yang sama. Promise di-resolve dengan jenis yang sama yang diteruskan ke callback.
clearDefaultFontSize()
chrome.fontSettings.clearDefaultFontSize(
details?: object,
callback?: function,
)
Menghapus ukuran font default yang ditetapkan oleh ekstensi ini, jika ada.
Parameter
-
detail
objek opsional
Parameter ini saat ini tidak digunakan.
-
callback
fungsi opsional
Parameter
callback
terlihat seperti:() => void
Hasil
-
Promise<void>
Chrome 96+Promise didukung di Manifes V3 dan yang lebih baru, tetapi callback disediakan untuk kompatibilitas mundur. Anda tidak dapat menggunakan keduanya pada panggilan fungsi yang sama. Promise di-resolve dengan jenis yang sama yang diteruskan ke callback.
clearFont()
chrome.fontSettings.clearFont(
details: object,
callback?: function,
)
Menghapus font yang ditetapkan oleh ekstensi ini, jika ada.
Parameter
-
detail
objek
-
genericFamily
Jenis font generik yang font-nya harus dihapus.
-
skrip
ScriptCode opsional
Skrip yang font-nya harus dihapus. Jika dihilangkan, setelan font skrip global akan dihapus.
-
-
callback
fungsi opsional
Parameter
callback
terlihat seperti:() => void
Hasil
-
Promise<void>
Chrome 96+Promise didukung di Manifes V3 dan yang lebih baru, tetapi callback disediakan untuk kompatibilitas mundur. Anda tidak dapat menggunakan keduanya pada panggilan fungsi yang sama. Promise di-resolve dengan jenis yang sama yang diteruskan ke callback.
clearMinimumFontSize()
chrome.fontSettings.clearMinimumFontSize(
details?: object,
callback?: function,
)
Menghapus ukuran font minimum yang ditetapkan oleh ekstensi ini, jika ada.
Parameter
-
detail
objek opsional
Parameter ini saat ini tidak digunakan.
-
callback
fungsi opsional
Parameter
callback
terlihat seperti:() => void
Hasil
-
Promise<void>
Chrome 96+Promise didukung di Manifes V3 dan yang lebih baru, tetapi callback disediakan untuk kompatibilitas mundur. Anda tidak dapat menggunakan keduanya pada panggilan fungsi yang sama. Promise di-resolve dengan jenis yang sama yang diteruskan ke callback.
getDefaultFixedFontSize()
chrome.fontSettings.getDefaultFixedFontSize(
details?: object,
callback?: function,
)
Mendapatkan ukuran default untuk font lebar tetap.
Parameter
-
detail
objek opsional
Parameter ini saat ini tidak digunakan.
-
callback
fungsi opsional
Parameter
callback
terlihat seperti:(details: object) => void
-
detail
objek
-
levelOfControl
Tingkat kontrol yang dimiliki ekstensi ini atas setelan.
-
pixelSize
angka
Ukuran font dalam piksel.
-
-
Hasil
-
Promise<object>
Chrome 96+Promise didukung di Manifes V3 dan yang lebih baru, tetapi callback disediakan untuk kompatibilitas mundur. Anda tidak dapat menggunakan keduanya pada panggilan fungsi yang sama. Promise di-resolve dengan jenis yang sama yang diteruskan ke callback.
getDefaultFontSize()
chrome.fontSettings.getDefaultFontSize(
details?: object,
callback?: function,
)
Mendapatkan ukuran font default.
Parameter
-
detail
objek opsional
Parameter ini saat ini tidak digunakan.
-
callback
fungsi opsional
Parameter
callback
terlihat seperti:(details: object) => void
-
detail
objek
-
levelOfControl
Tingkat kontrol yang dimiliki ekstensi ini atas setelan.
-
pixelSize
angka
Ukuran font dalam piksel.
-
-
Hasil
-
Promise<object>
Chrome 96+Promise didukung di Manifes V3 dan yang lebih baru, tetapi callback disediakan untuk kompatibilitas mundur. Anda tidak dapat menggunakan keduanya pada panggilan fungsi yang sama. Promise di-resolve dengan jenis yang sama yang diteruskan ke callback.
getFont()
chrome.fontSettings.getFont(
details: object,
callback?: function,
)
Mendapatkan font untuk skrip tertentu dan jenis font generik.
Parameter
-
detail
objek
-
genericFamily
Jenis font generik yang font-nya harus diambil.
-
skrip
ScriptCode opsional
Skrip yang font-nya harus diambil. Jika dihilangkan, setelan font untuk skrip global (kode skrip "Zyyy") akan diambil.
-
-
callback
fungsi opsional
Parameter
callback
terlihat seperti:(details: object) => void
-
detail
objek
-
fontId
string
ID font. Ini mungkin ID font yang digunakan sistem untuk me-resolve nilai preferensi, bukan nilai preferensi ID font literal. Jadi,
fontId
dapat berbeda dari font yang diteruskan kesetFont
, jika, misalnya, font tidak tersedia di sistem. String kosong menandakan penggantian ke setelan font skrip global. -
levelOfControl
Tingkat kontrol yang dimiliki ekstensi ini atas setelan.
-
-
Hasil
-
Promise<object>
Chrome 96+Promise didukung di Manifes V3 dan yang lebih baru, tetapi callback disediakan untuk kompatibilitas mundur. Anda tidak dapat menggunakan keduanya pada panggilan fungsi yang sama. Promise di-resolve dengan jenis yang sama yang diteruskan ke callback.
getFontList()
chrome.fontSettings.getFontList(
callback?: function,
)
Mendapatkan daftar font di sistem.
Parameter
Hasil
-
Promise<FontName[]>
Chrome 96+Promise didukung di Manifes V3 dan yang lebih baru, tetapi callback disediakan untuk kompatibilitas mundur. Anda tidak dapat menggunakan keduanya pada panggilan fungsi yang sama. Promise di-resolve dengan jenis yang sama yang diteruskan ke callback.
getMinimumFontSize()
chrome.fontSettings.getMinimumFontSize(
details?: object,
callback?: function,
)
Mendapatkan ukuran font minimum.
Parameter
-
detail
objek opsional
Parameter ini saat ini tidak digunakan.
-
callback
fungsi opsional
Parameter
callback
terlihat seperti:(details: object) => void
-
detail
objek
-
levelOfControl
Tingkat kontrol yang dimiliki ekstensi ini atas setelan.
-
pixelSize
angka
Ukuran font dalam piksel.
-
-
Hasil
-
Promise<object>
Chrome 96+Promise didukung di Manifes V3 dan yang lebih baru, tetapi callback disediakan untuk kompatibilitas mundur. Anda tidak dapat menggunakan keduanya pada panggilan fungsi yang sama. Promise di-resolve dengan jenis yang sama yang diteruskan ke callback.
setDefaultFixedFontSize()
chrome.fontSettings.setDefaultFixedFontSize(
details: object,
callback?: function,
)
Menetapkan ukuran default untuk font lebar tetap.
Parameter
-
detail
objek
-
pixelSize
angka
Ukuran font dalam piksel.
-
-
callback
fungsi opsional
Parameter
callback
terlihat seperti:() => void
Hasil
-
Promise<void>
Chrome 96+Promise didukung di Manifes V3 dan yang lebih baru, tetapi callback disediakan untuk kompatibilitas mundur. Anda tidak dapat menggunakan keduanya pada panggilan fungsi yang sama. Promise di-resolve dengan jenis yang sama yang diteruskan ke callback.
setDefaultFontSize()
chrome.fontSettings.setDefaultFontSize(
details: object,
callback?: function,
)
Menetapkan ukuran font default.
Parameter
-
detail
objek
-
pixelSize
angka
Ukuran font dalam piksel.
-
-
callback
fungsi opsional
Parameter
callback
terlihat seperti:() => void
Hasil
-
Promise<void>
Chrome 96+Promise didukung di Manifes V3 dan yang lebih baru, tetapi callback disediakan untuk kompatibilitas mundur. Anda tidak dapat menggunakan keduanya pada panggilan fungsi yang sama. Promise di-resolve dengan jenis yang sama yang diteruskan ke callback.
setFont()
chrome.fontSettings.setFont(
details: object,
callback?: function,
)
Menetapkan font untuk skrip tertentu dan jenis font generik.
Parameter
-
detail
objek
-
fontId
string
ID font. String kosong berarti kembali ke setelan font skrip global.
-
genericFamily
Jenis font generik yang fontnya harus ditetapkan.
-
skrip
ScriptCode opsional
Kode skrip yang harus ditetapkan fontnya. Jika dihilangkan, setelan font untuk skrip global (kode skrip "Zyyy") akan ditetapkan.
-
-
callback
fungsi opsional
Parameter
callback
terlihat seperti:() => void
Hasil
-
Promise<void>
Chrome 96+Promise didukung di Manifes V3 dan yang lebih baru, tetapi callback disediakan untuk kompatibilitas mundur. Anda tidak dapat menggunakan keduanya pada panggilan fungsi yang sama. Promise di-resolve dengan jenis yang sama yang diteruskan ke callback.
setMinimumFontSize()
chrome.fontSettings.setMinimumFontSize(
details: object,
callback?: function,
)
Menetapkan ukuran font minimum.
Parameter
-
detail
objek
-
pixelSize
angka
Ukuran font dalam piksel.
-
-
callback
fungsi opsional
Parameter
callback
terlihat seperti:() => void
Hasil
-
Promise<void>
Chrome 96+Promise didukung di Manifes V3 dan yang lebih baru, tetapi callback disediakan untuk kompatibilitas mundur. Anda tidak dapat menggunakan keduanya pada panggilan fungsi yang sama. Promise di-resolve dengan jenis yang sama yang diteruskan ke callback.
Acara
onDefaultFixedFontSizeChanged
chrome.fontSettings.onDefaultFixedFontSizeChanged.addListener(
callback: function,
)
Diaktifkan saat setelan ukuran font tetap default berubah.
Parameter
-
callback
fungsi
Parameter
callback
terlihat seperti:(details: object) => void
-
detail
objek
-
levelOfControl
Tingkat kontrol yang dimiliki ekstensi ini atas setelan.
-
pixelSize
angka
Ukuran font dalam piksel.
-
-
onDefaultFontSizeChanged
chrome.fontSettings.onDefaultFontSizeChanged.addListener(
callback: function,
)
Diaktifkan saat setelan ukuran font default berubah.
Parameter
-
callback
fungsi
Parameter
callback
terlihat seperti:(details: object) => void
-
detail
objek
-
levelOfControl
Tingkat kontrol yang dimiliki ekstensi ini atas setelan.
-
pixelSize
angka
Ukuran font dalam piksel.
-
-
onFontChanged
chrome.fontSettings.onFontChanged.addListener(
callback: function,
)
Diaktifkan saat setelan font berubah.
Parameter
-
callback
fungsi
Parameter
callback
terlihat seperti:(details: object) => void
-
detail
objek
-
fontId
string
ID font. Lihat deskripsi di
getFont
. -
genericFamily
Jenis font generik yang setelan font-nya telah diubah.
-
levelOfControl
Tingkat kontrol yang dimiliki ekstensi ini atas setelan.
-
skrip
ScriptCode opsional
Kode skrip yang setelan font-nya telah diubah.
-
-
onMinimumFontSizeChanged
chrome.fontSettings.onMinimumFontSizeChanged.addListener(
callback: function,
)
Diaktifkan saat setelan ukuran font minimum berubah.
Parameter
-
callback
fungsi
Parameter
callback
terlihat seperti:(details: object) => void
-
detail
objek
-
levelOfControl
Tingkat kontrol yang dimiliki ekstensi ini atas setelan.
-
pixelSize
angka
Ukuran font dalam piksel.
-
-