溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何解決iOS自定義字體顯示問題

發(fā)布時間:2021-09-27 14:35:06 來源:億速云 閱讀:126 作者:小新 欄目:編程語言

小編給大家分享一下如何解決iOS自定義字體顯示問題,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

1. 自定義字體出什么問題了?

設計師們的作品總是千變?nèi)f化,為了成就他們,作為程序員的我們只好滿足他們嘍。

所以當設計師用到一款神奇的字體的時候,我是不會拒絕的,就像下面這個樣子:

為了讓大家能更好的看到這個問題,我把 label 設置了一個背景色,label 的 width 和 height 都等于50。現(xiàn)在,在 storyboard 中看起來是沒問題的,讓我們 Run 一下:

對比 system font 字體的 label,明顯感覺這個 DINCondensedC 字體的內(nèi)容是偏上的?。ó斎徊挥脤Ρ纫材馨l(fā)現(xiàn))。WTF!

2. 解決思路

2.1 既然是內(nèi)容偏上,那么是否和 content Mode 有關?

可惜的是,經(jīng)過嘗試,改變 contentMode 并不能對 UILabel 產(chǎn)生任何影響(實際繪制內(nèi)容中包含下方的空白)。

結(jié)論:不可行

2.2 繼承 UILabel 并重寫 drawRect ?利用 CoreText 繪制字體?

這兩種方案應該是可行的,但是,為了這個小字體,用得著這么復雜的【計算字體大小】-【通過字體大小與 label 高度計算偏移量】-【用到這個字體的 label 統(tǒng)一換成 XXLabel 】流程嗎?

萬一哪天設計師說:來,咱們來個富文本,中間這幾個字用 DINCondensedC 字體,兩邊的字用 system 字體,那你不是要哭了?

結(jié)論:不可行

2.3 程序解決不了,那就用人解決吧

讓我們找到可愛的設計師,請他喝個下午茶,搓頓不錯的晚飯,帶他做個大保健,然后和他說:兄弟這個UI圖可以換個字體嗎... 算了成本有點高。

結(jié)論:不可行

2.4 可否從字體入手,自己修改字體?

既然字體有點不太正常,那么我們只能使出大招:自己動手修改這個字體。據(jù)說有一款 App:Glyphs 對于制作/修改字體來說,很強大!然后讓我們好好下載,靜靜等待吧。下載完畢打開這個【PT DIN Condensed Cyrillic.ttf】字體文件,沒想到這個軟件還收費,只能試用幾天。試用就使用吧,但是,這個字體里的每個字符我都要一個一個去改?作為程序員,不能忍!

結(jié)論:不可行

3. 最終的解決方案

最后還是得靠蘋果爸爸,大家的好爸爸。蘋果提供了一款字體修改工具:Apple Font Tool Suite。下面就讓我們用該工具來解決這個棘手的問題。

3.1 下載該工具

進入這里,滾到最下方,可以看到【Apple Font Tool Suite】,點擊下方的下載,下載一個適合自己 Xcode 版本,下載完成后無腦安裝。

3.2 獲取字體的信息文件

打開終端,輸入:ftxdumperfuser -t hhea -A d PT\ DIN\ Condensed\ Cyrillic.ttf,前面的【ftxdumperfuser -t hhea -A d 】為指令,后面的為你的字體文件路徑。最后回車,你會看到同級文件夾下回多出一個【DINCondensedC.hhea.xml】文件:

3.3 修改字體文件中的信息

讓我們打開這個字體文件,你會看到:

<?xml version="1.0" encoding="UTF-8" standalone="no" ?><!DOCTYPE hheaTable [<!ELEMENT hheaTable EMPTY><!ATTLIST hheaTable versionMajor CDATA #IMPLIEDversionMinor CDATA #IMPLIEDascender CDATA #IMPLIEDdescender CDATA #IMPLIEDlineGap CDATA #IMPLIEDadvanceWidthMax CDATA #IMPLIEDminLeftSideBearing CDATA #IMPLIEDminRightSideBearing CDATA #IMPLIEDxMaxExtent CDATA #IMPLIEDcaretSlopeRise CDATA #IMPLIEDcaretSlopeRun CDATA #IMPLIEDcaretOffset CDATA #IMPLIEDmetricDataFormat CDATA #IMPLIEDnumberOfHMetrics CDATA #IMPLIED>]><!--Data generated Sun Aug 13 18:51:10 2017Generated by ftxdumperfuser build 347,FontToolbox.framework build 257Font full name: 'PT DIN Condensed Cyrillic'Font PostScript name: 'DINCondensedC'--><hheaTableversionMajor="1"versionMinor="0"ascender="700"descender="-209"lineGap="68"advanceWidthMax="889"minLeftSideBearing="-270"minRightSideBearing="-22"xMaxExtent="844"caretSlopeRise="1"caretSlopeRun="0"caretOffset="0"metricDataFormat="0"numberOfHMetrics="234"/>

沒錯這是個 XML 文件,它里面包含了字體的一些公共信息:

ascender:從字體的 baseLine 到最高處的距離descender:從字體的 baseline 到最低點的距離lineGap:印刷線的間距...

這里面的每一項信息,都可以從蘋果的:hheaTable文檔 這篇文檔中找到。文檔中可以看到,一款字體也是一個大工程。今天我們要解決的,是【DINCondensedC】字體偏上的問題,因此,讓我們來調(diào)節(jié)調(diào)節(jié) ascender 這個屬性,將它從700改為900,然后保存文件。

3.4 將修改完的文件注入原 ttf 文件

打開終端,輸入:ftxdumperfuser -t hhea -A f PT\ DIN\ Condensed\ Cyrillic.ttf,注意這里 -A 后面的 d 已經(jīng)換成了 f ,回車。

3.5 替換原工程中的字體文件

切回我們的工程,替換原字體文件,Run 一下

以上是“如何解決iOS自定義字體顯示問題”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業(yè)資訊頻道!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

ios
AI