התכונה 'גופנים להורדה' מאפשרת לממשקי API לבקש גופנים מאפליקציית ספק במקום לארוז קבצים באפליקציה או לאפשר לאפליקציה להוריד גופנים. התכונה 'גופנים להורדה' זמינה במכשירים עם Android מגרסה 14 ואילך דרך ספריית AndroidX Core.
היתרונות של גופנים להורדה:
הקטנת גודל האפליקציה, וכך הגדלת שיעור ההצלחה של התקנת האפליקציה.
השירות הזה משפר את התקינות הכוללת של המערכת, כי כמה אפליקציות יכולות לשתף את אותו גופן דרך ספק. כך המשתמשים חוסכים בחבילת הגלישה, בזיכרון הטלפון ובמקום בדיסק. במודל הזה, הגופן מאוחזר דרך הרשת כשצריך אותו.
כדי לנסות את התכונה 'גופנים להורדה', אפשר לעיין באפליקציית הדוגמה DownloadableFonts.
איך פועלים גופנים להורדה?
ספק גופנים הוא אפליקציה שמחלצת גופנים ומאחסנת אותם במטמון באופן מקומי, כדי שאפליקציות אחרות יוכלו לבקש ולשתף גופנים. האיור הבא מדגים את התהליך.
איור 1. תהליך ההורדה של גופנים.
העקרונות הבסיסיים
אפשר להשתמש בתכונה 'גופנים להורדה' בדרכים הבאות, שמפורטות בקטעים הבאים:
שימוש בגופנים להורדה עם Android Studio ושירותי Google Play
אתם יכולים להגדיר את האפליקציה להורדת גופנים באמצעות Android Studio בגרסה 3.0 ואילך. כדי לעזור לכם להתחיל להשתמש בתכונות של גופנים להורדה, אתם יכולים להשתמש בספק הגופנים מ-Google Play Services.
בכלי לעריכת פריסות, בוחרים בTextView. לאחר מכן, בקטע מאפיינים,
בוחרים באפשרות fontFamily > עוד גופנים.
איור 2. שימוש בעורך הפריסות.
מופיע החלון Resources.
בתפריט מקור, בוחרים באפשרות גופנים של Google.
בתיבה גופנים, בוחרים גופן באזור 'ניתן להורדה'.
בוחרים באפשרות יצירת גופן להורדה ולוחצים על אישור.
איור 3. בחירת גופן מהחלון Resources.
Android Studio יוצר באופן אוטומטי את קובצי ה-XML הרלוונטיים שנדרשים כדי שהגופן יוצג בצורה נכונה באפליקציה.
איור 4. תצוגה מקדימה של קובץ הגופן.
שימוש בגופנים להורדה באופן פרוגרמטי
החל מ-Android 8.0 (רמת API 26), AndroidX Core מספק תמיכה מלאה בגופנים להורדה. מידע נוסף על שימוש בספריית AndroidX Core זמין בקטע ספריית AndroidX Core של גופנים להורדה בדף הזה.
כדי להשתמש בתכונה 'גופנים להורדה' באופן פרוגרמטי, צריך לקיים אינטראקציה עם שתי מחלקות מפתח:
האפליקציה מאחזרת גופנים מספק הגופנים באמצעות FontsContract API. לכל ספק יש קבוצה משלו של הגבלות על גרסאות Android ושפת השאילתות שהוא תומך בהן. למידע נוסף על גרסאות Android ועל פורמט השאילתה, אפשר לעיין במסמכי התיעוד של הספק.
כדי להוריד גופן, פועלים לפי השלבים הבאים:
יוצרים מופע של המחלקה android.graphics.fonts.FontRequest כדי לבקש את הגופן מהספק. כדי ליצור בקשה, מעבירים את הפרמטרים הבאים:
הגורם המוסמך של ספק הגופנים.
חבילת ספק הגופנים לאימות הזהות של הספק.
מחרוזת השאילתה של הגופן. מידע נוסף על פורמטים של שאילתות זמין במסמכי התיעוד של ספק הגופנים, כמו Google Fonts.
מבטלים את ההגדרה של השיטה
onTypefaceRetrieved()
כדי לציין שהבקשה לגופן הושלמה. מספקים את הגופן שאוחזר כפרמטר.
אתם יכולים להשתמש בשיטה הזו כדי להגדיר את הגופן לפי הצורך. לדוגמה, אפשר להגדיר את הגופן ב-TextView.
מפעילים את השיטה FontsContract.requestFont() כדי לאחזר את הגופן מספק הגופנים. השיטה מתחילה בדיקה כדי לקבוע אם הגופן קיים במטמון. אם הגופן לא זמין באופן מקומי, הפונקציה קוראת לספק הגופנים, מאחזרת את הגופן באופן אסינכרוני ומעבירה את התוצאה לקריאה החוזרת. מעבירים את הפרמטרים הבאים:
קוד לדוגמה שממחיש את התהליך הכולל של גופנים להורדה:
Kotlin
valrequest=FontRequest("com.example.fontprovider.authority","com.example.fontprovider","my font",certs)valcallback=object:FontsContract.FontRequestCallback(){overridefunonTypefaceRetrieved(typeface:Typeface){// Your code to use the font goes here....}overridefunonTypefaceRequestFailed(reason:Int){// Your code to deal with the failure goes here....}}FontsContract.requestFonts(context,request,handler,null,callback)
Java
FontRequestrequest=newFontRequest("com.example.fontprovider.authority","com.example.fontprovider","my font",certs);FontsContract.FontRequestCallbackcallback=newFontsContract.FontRequestCallback(){@OverridepublicvoidonTypefaceRetrieved(Typefacetypeface){// Your code to use the font goes here....}@OverridepublicvoidonTypefaceRequestFailed(intreason){// 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
כוללת את המחלקות FontsContractCompat ו-FontRequest כדי להטמיע תמיכה בתכונה 'גופנים ניתנים להורדה' שתואמת לאחור. המחלקות של AndroidX מכילות שיטות שדומות לשיטות של המסגרת, והתהליך של הורדת גופנים דומה לזה שמתואר בקטע בדף הזה בנושא שימוש בגופנים להורדה באופן פרוגרמטי.
כדי להוריד גופנים באמצעות AndroidX, מייבאים את המחלקות FontsContractCompat ו-FontRequest מהחבילה androidx.core.provider. ליצור מופעים של הכיתות האלה במקום כיתות של מסגרת FontsContract ו-android.graphics.fonts.FontRequest.
הוספת יחסי תלות של AndroidX Core
כדי להשתמש במחלקות FontsContractCompat ו-FontRequest, צריך לשנות את התלויות בנתיב המחלקה של פרויקט האפליקציה בסביבת הפיתוח.
כדי להוסיף את AndroidX Core לפרויקט האפליקציה, מוסיפים את התלות הבאה לקובץ build.gradle של האפליקציה:
Android 8.0 (רמת API 26) ו-AndroidX Core מציעים דרך מהירה ונוחה יותר להצהרה על גופן מותאם אישית כמשאב בפריסת ה-XML. המשמעות היא שאין צורך לארוז את הגופן כנכס. אתם יכולים להגדיר גופן בהתאמה אישית לכל העיצוב, וכך לשפר את נוחות השימוש בכמה משקלים וסגנונות, כמו מודגש, בינוני או קליל, אם הם זמינים.
יוצרים קובץ XML חדש בתיקייה res/font.
מוסיפים רכיב בסיס <font-family> ומגדירים את המאפיינים שקשורים לגופן, כמו בדוגמה הבאה של קובץ XML:
מפנים לקובץ כאל @font/font_file_name בקובץ ה-XML של הפריסה. אפשר גם להשתמש בשיטה getFont() כדי לאחזר את הקובץ באופן פרוגרמטי, למשל getFont(R.font.font_file_name).
הצהרה מראש על גופנים במניפסט
הגדלת הפריסה ואחזור המשאבים הן משימות סינכרוניות. כברירת מחדל, הניסיון הראשון לאחזר גופנים מפעיל בקשה לספק הגופנים, ולכן מגדיל את הזמן של הפריסה הראשונה. כדי למנוע את העיכוב, אפשר להצהיר מראש על גופנים שצריך לאחזר במניפסט.
אחרי שהמערכת מאחזרת את הגופן מהספק, הוא זמין באופן מיידי. אם אחזור הגופן נמשך יותר זמן מהצפוי, המערכת מבטלת את תהליך האחזור ומשתמשת בגופן ברירת המחדל.
כדי להצהיר מראש על גופנים בקובץ המניפסט, צריך לבצע את השלבים הבאים:
יוצרים מערך של משאבים ב-res/values/arrays.xml ומצהירים על הגופנים שרוצים לבצע להם אחזור מראש.
אם ספק הגופנים לא מותקן מראש, או אם אתם משתמשים בספריית הליבה של AndroidX, צריך להצהיר על האישורים שספק הגופנים חתום עליהם. המערכת משתמשת באישורים כדי לאמת את הזהות של ספק הגופנים.
כדי להוסיף אישורים:
יוצרים מערך מחרוזות עם פרטי האישור. למידע נוסף על פרטי האישור, אפשר לעיין במסמכי התיעוד של ספק הגופנים.
דוגמאות התוכן והקוד שבדף הזה כפופות לרישיונות המפורטים בקטע רישיון לתוכן. Java ו-OpenJDK הם סימנים מסחריים או סימנים מסחריים רשומים של חברת Oracle ו/או של השותפים העצמאיים שלה.
עדכון אחרון: 2025-10-22 (שעון UTC).
[[["התוכן קל להבנה","easyToUnderstand","thumb-up"],["התוכן עזר לי לפתור בעיה","solvedMyProblem","thumb-up"],["סיבה אחרת","otherUp","thumb-up"]],[["חסרים לי מידע או פרטים","missingTheInformationINeed","thumb-down"],["התוכן מורכב מדי או עם יותר מדי שלבים","tooComplicatedTooManySteps","thumb-down"],["התוכן לא עדכני","outOfDate","thumb-down"],["בעיה בתרגום","translationIssue","thumb-down"],["בעיה בדוגמאות/בקוד","samplesCodeIssue","thumb-down"],["סיבה אחרת","otherDown","thumb-down"]],["עדכון אחרון: 2025-10-22 (שעון UTC)."],[],[]]