新聞中心

        EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > Core Text在繪制的時(shí)候碰到行間距問(wèn)題的原因及解決

        Core Text在繪制的時(shí)候碰到行間距問(wèn)題的原因及解決

        作者: 時(shí)間:2016-09-12 來(lái)源:網(wǎng)絡(luò) 收藏

        實(shí)在受不了目前沒(méi)有一個(gè)比較完善的庫(kù)來(lái)解決@人名、鏈接及表情的混排問(wèn)題。

        本文引用地址:http://www.104case.com/article/201609/304766.htm

        fork了一下TTTAttributedLabel修改了一下https://github.com/qdvictory/TTTAttributedLabel

        pull回去已經(jīng)被commit了,可以直接查看https://github.com/mattt/TTTAttributedLabel

        在解釋原因之前,需要先提出幾個(gè)屬性。

        CLLine CTLineGetTypographicBounds 取出的 ascent descent leading

        UIFont 取出的lineHeight descender ascender leading 特別提一下,descender為負(fù)值,ascender為正值

        關(guān)于相關(guān)的屬性解釋,用一張圖來(lái)展示

        在Core Text中,UIFont及CLLineRef都會(huì)有一套自己的間距數(shù)據(jù)。問(wèn)題就出在了CLLine上。

        利用CTLineGetTypographicBounds取出的descender、ascender、leading會(huì)根據(jù)當(dāng)前行里面含有字符計(jì)算出來(lái)。當(dāng)此行中含有emoji或中英文之后,計(jì)算出來(lái)的數(shù)值必然與其它行有出入,出現(xiàn)行距不統(tǒng)一的問(wèn)題。

        我們要做的就是要將每行重新對(duì)齊。

        設(shè)想一下CLLine每行都有一條基線,如果讓每行都以底對(duì)齊,那么就是在CLLine的繪制原點(diǎn)減去descent,此時(shí)當(dāng)前行就為底對(duì)齊。

        接下來(lái)的問(wèn)題又出現(xiàn)了,如果只是單純這樣操作的話,(因?yàn)檫M(jìn)行了坐標(biāo)轉(zhuǎn)換)每行都會(huì)下降n像素,肯定會(huì)超出label的下范圍,所以我們需要再給他一個(gè)下行的距離,而這個(gè)距離最理想的數(shù)值就是font.descender。

        因而就有了代碼

        CGContextSetTextPosition(c, lineOrigin.x, lineOrigin.y-descent-self.font.descender);

        由此我們的目的就達(dá)到了,同時(shí)也希望以后遇到此問(wèn)題的人有些參考。

        附2張效果圖。

        默認(rèn)情況下

        默認(rèn)情況下

        修改之后

        修改之后



        關(guān)鍵詞:

        評(píng)論


        相關(guān)推薦

        技術(shù)專區(qū)

        關(guān)閉
        主站蜘蛛池模板: 敦化市| 中超| 永清县| 安国市| 长宁县| 宝坻区| 灯塔市| 黄龙县| 石台县| 惠来县| 会泽县| 兰考县| 永靖县| 长治市| 大埔县| 宁晋县| 上栗县| 南平市| 乐平市| 丰县| 商洛市| 榕江县| 武宣县| 上饶市| 公主岭市| 体育| 铜鼓县| 昌宁县| 成安县| 平武县| 玉门市| 崇义县| 黄骅市| 筠连县| 蓝田县| 西乌珠穆沁旗| 大英县| 白朗县| 宽甸| 潜山县| 济南市|