chrome.fontSettings

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()

Promise
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()

Promise
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()

Promise
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()

Promise
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()

Promise
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()

Promise
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()

Promise
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 ke setFont, 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()

Promise
chrome.fontSettings.getFontList(
  callback?: function,
)

Mendapatkan daftar font di sistem.

Parameter

  • callback

    fungsi opsional

    Parameter callback terlihat seperti:

    (results: FontName[]) => void

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()

Promise
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()

Promise
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()

Promise
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()

Promise
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()

Promise
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.