ใน Android 11 และต่ำกว่า การอัปเดตไฟล์แบบอักษรที่ติดตั้งในอุปกรณ์ใน AOSP (ใน
พาร์ติชัน /system/fonts
) หรือพาร์ติชันผู้ให้บริการ (ใน /product/fonts
หรือ
/system/fonts
พาร์ติชัน) ต้องมีการอัปเดตระบบจาก OEM ช่วงเวลานี้
ข้อกำหนดมีผลอย่างมากต่อความเข้ากันได้กับอีโมจิ ใน
Android 12 คุณสามารถใช้ระบบ FontManager
ได้
บริการเพื่อจัดการไฟล์แบบอักษรที่ติดตั้งไว้และอัปเดตไฟล์แบบอักษรที่ติดตั้งในอุปกรณ์
โดยไม่ต้องอัปเดตระบบ
Android 12 จะมีการโต้ตอบกระบวนการ 3 กระบวนการ ได้แก่
FontManagerService
, Font Updater
และ Application
FontManagerService
เป็นระบบการจัดการส่วนกลางในเซิร์ฟเวอร์ระบบ
FontManagerService
จะจัดเก็บการตั้งค่าแบบอักษรของระบบต่อผู้ใช้ล่าสุด
FontUpdater
เป็นเครื่องมืออัปเดตแบบอักษรที่เสียบได้ ซึ่งได้รับความไว้วางใจจาก
ตรวจสอบสิทธิ์ของ signature|privileged
FontUpdater
สื่อสารกับ
FontManagerService
เพื่อรับ ติดตั้ง นำออก หรืออัปเดตแบบอักษรของระบบปัจจุบัน
การตั้งค่า FontUpdater
สามารถส่งเนื้อหาไฟล์แบบอักษรใหม่ด้วยแท็กระหว่างโปรเซส
การสื่อสาร (IPC) FontManagerService
บันทึกเนื้อหาไปยัง
ตำแหน่งที่เก็บข้อมูลที่สามารถอ่านได้ทั่วโลก เช่น ในไฟล์ /data/fonts
ช่วงเวลานี้
พื้นที่เก็บข้อมูลมีการป้องกัน สามารถเขียนโดย FontManagerService
เท่านั้น โดย
นโยบาย SELinux
เมื่อคลาส Application
เปิดขึ้น ระบบจะส่งการตั้งค่าแบบอักษรของระบบเป็น
อาร์กิวเมนต์ของเมธอด bindApplication
จากนั้นจะเป็นการเริ่มต้นการตั้งค่าแบบอักษร
เพื่อนำไปใช้โดยกระบวนการของแอป
ปรับแต่งแบบอักษร
OEM บางรายจะติดตั้งหรือแทนที่ไฟล์แบบอักษรใน AOSP เพื่อแสดงแบรนด์ของตน Android 12 รองรับฟังก์ชันนี้ แต่เพิ่ม ข้อกำหนดอื่นๆ เพื่ออัปเดตแบบอักษรอีโมจิในอุปกรณ์อยู่เสมอ OEM ที่ไม่ดัดแปลงหรือ อัปเดตไฟล์แบบอักษรอีโมจิไม่จำเป็นต้องใช้ฟีเจอร์นี้
Google อัปเดตไฟล์แบบอักษร โดยเฉพาะไฟล์ NotoColorEmoji
ผ่าน GMS
หลัก ดังนั้นห้ามแก้ไขหรือนำไฟล์ NotoColorEmoji.ttf
ออกจาก
/system
พาร์ติชัน และอย่านำออกจาก /system/etc/fonts.xml
โปรดทราบ
ต่อไปนี้ 3 วิธีในการปรับแต่งแบบอักษร
- แทนที่ไฟล์
NotoColorEmoji.ttf
ด้วยแบบอักษรอีโมจิแบรนด์ OEM - แก้ไขไฟล์
NotoColorEmoji.ttf
ตามความต้องการของตลาดท้องถิ่น - แทนที่หรือแก้ไขไฟล์แบบอักษรอื่นๆ
หากคุณไม่ได้แก้ไขแบบอักษรอีโมจิใน AOSP คุณก็ไม่ต้องดำเนินการใดๆ ถ้า ที่ต้องการปรับแต่งแบบอักษรอีโมจิ โปรดใช้วิธีการดังต่อไปนี้
แทนที่ NotoColorEmoji.ttf ด้วยแบบอักษรอีโมจิที่เป็นแบรนด์ OEM
หากต้องการแทนที่ไฟล์ NotoColorEmoji.ttf
ด้วยไฟล์แบบอักษรอีโมจิของแบรนด์ OEM
ใส่แบบอักษรอีโมจิไว้หน้าชุดแบบอักษรสำรอง
- วางแบบอักษรของคุณเองซึ่งเรียกว่า
OEMCustomEmoji.ttf
ในพาร์ติชัน/system
แก้ไข
/system/etc/fonts.xml
ในโค้ดต่อไปนี้<family lang="ko"> <font weight="400" style="normal" index="1">NotoSansCJK-Regular.ttc</font> </family> <!-- ADD FOLLOWING LINE --> <family lang="und-Zsye"> <font weight="400" style="normal">OEMCustomEmoji.ttf</font> </family> <!-- END OF MODIFICATION --> <family lang="und-Zsye"> <font weight="400" style="normal">NotoColorEmoji.ttf</font> </family> <family lang="und-Zsym"> <font weight="400" style="normal">NotoSansSymbols-Regular-Subsetted2.ttf</font> </family>
แก้ไข NotoColorEmoji.ttf เพื่อตอบสนองความต้องการของตลาดท้องถิ่น
ทำตามขั้นตอนต่อไปนี้เพื่อปรับแต่งตามความต้องการของตลาดในพื้นที่
- สร้างไฟล์
NotoColorEmoji
ของคุณเองโดยใช้ชื่ออื่น ตัวอย่างเช่น ตั้งชื่อว่าModified\_NotoColorEmoji.ttf
- วางโค้ดไว้หน้าไฟล์
NotoColorEmoji.ttf
ต้นฉบับ
หลังจากดำเนินการขั้นตอนที่ 2 สัญลักษณ์รูปที่ปรับแต่งซึ่งสนับสนุนโดย
Modified\NotoColorEmoji.ttf
แสดงแทน NotoColorEmoji.ttf
เดิม
Google ขอแนะนำให้ดำเนินการดังต่อไปนี้
- มีรูปอักขระที่จำเป็นในแบบอักษรนี้เท่านั้น
- มอบสิทธิ์รูปสัญลักษณ์ที่ไม่มีการแก้ไขให้กับไฟล์
NotoColorEmoji.ttf
ต้นฉบับเพื่อให้ อุปกรณ์ของคุณจะได้รับการแก้ไขด้านการออกแบบที่จะมีขึ้นสำหรับอีโมจิรุ่นต่อๆ ไป
นำรูปอักขระออก: หากต้องการนำรูปอักขระออกจากไฟล์ NotoColorEmoji.ttf
ให้ทำตาม
ขั้นตอนที่ 1 และ 2 และระบุ glyph ID = 0
ใน cmap ของคุณ
ใช้ธงประจำภูมิภาค: หากรูปอักขระเป้าหมายเป็นธงประจำภูมิภาค ให้ระบุ
รหัสรูปอักขระเป็นรหัสประเทศที่ไม่รู้จัก (ใช้ country code = "ZZ"
)
สร้างรูปอักขระเต้าหู้: คุณสามารถระบุรหัสรูปอักขระเต้าหู้อย่างชัดแจ้งได้หากต้องการ
เพื่อใช้แอปได้ เมื่อคุณระบุ glyphID = 0
แอปที่เกี่ยวข้องจะตีความว่า
"รูปอักขระไม่พร้อมใช้งาน" ตัวอย่างเช่น เมื่อคุณใช้แอตทริบิวต์นี้ พารามิเตอร์
แอป Paint#hasGlyph
แสดงผล false
แทนที่หรือแก้ไขไฟล์แบบอักษรอื่นๆ
ในการแทนที่หรือแก้ไขแบบอักษรอื่นๆ การกำหนดค่าจะคล้ายคลึงกับแบบอักษรดังกล่าวสำหรับ สำหรับการแก้ไขไฟล์ TTF ตามความต้องการของตลาดท้องถิ่น ไฟล์แบบอักษรที่ไม่รู้จักที่ ระบบจะไม่สนใจการอัปเดตใน AOSP ขณะรันไทม์ และจะไม่อัปเดต Google ไม่สนใจ แบบอักษรที่ไม่รู้จักในอุปกรณ์ของคุณ ซึ่งรวมถึงไฟล์แบบอักษรที่แก้ไข แบบอักษรดั้งเดิมใน AOSP
แม้ว่าการอัปเดตแบบอักษรจะดำเนินการโดย Google ใน GMS Core แต่การอัปเดตแบบอักษรทั่วไป เปิดกว้างสำหรับ OEM ทั้งหมด OEM สามารถติดตั้งโปรแกรมอัปเดตแบบอักษรเพิ่มเติมได้โดยใช้ ขั้นตอนในข้อกำหนดเบื้องต้นของการประชุม การเซ็นชื่อในไฟล์แบบอักษร และการอัปเดตแบบอักษรรันไทม์
ข้อกำหนดเบื้องต้นของ Meet
กลไกการอัปเดตแบบอักษรจะใช้ฟีเจอร์เคอร์เนลของ fs-verity
ของ Linux โปรดยืนยันว่า
อุปกรณ์ของคุณเป็นไปตามข้อกำหนดของfs-verity
และมีใบรับรองอยู่ในอุปกรณ์
เซ็นชื่อในไฟล์แบบอักษร
เนื่องจากไฟล์แบบอักษรเป็นทรัพยากรที่มีความเสี่ยง จึงต้องยืนยันด้วยคีย์ที่เชื่อถือได้
ตรวจสอบไฟล์แบบอักษรทั้งหมดที่จะอัปเดตอย่างละเอียด และลงชื่อเข้าใช้
คีย์ส่วนตัว ลายเซ็นต้องเข้ากันได้กับ fs-verity
อัปเดตแบบอักษรแบบรันไทม์
แอประบบ FontManger
จะอัปเดตแบบอักษร แอป FontManager
มี
สถานะแบบอักษรของระบบที่ติดตั้งล่าสุดและความสามารถในการอัปเดตไฟล์แบบอักษร
ด้วยลายเซ็น หากต้องการเรียกใช้แอปอัปเดตแอป ให้เพิ่ม UPDATE_FONT signature|privileged
สิทธิ์ในรายการแอปที่อนุญาต
และ ลงในไฟล์ Manifest
ให้สิทธิ์ UPDATE_FONT signature|privileged
แก่โปรแกรมอัปเดตของแอป