android canvas drawText()文字居中效果
本文跟大家分享下我關(guān)于drawText()文字居中的方法。
先附上drawText()的方法說(shuō)明
說(shuō)實(shí)話當(dāng)時(shí)看了這個(gè),我也沒(méi)明白這個(gè)x,y坐標(biāo)到底表達(dá)的啥意思,還一直以為是繪制文字中心的坐標(biāo),后來(lái)發(fā)現(xiàn)這個(gè)理解是錯(cuò)誤的
要想理解這個(gè)首先看張圖
像圖上這樣安卓的文字繪制是相對(duì)于基線繪制的,也就是圖中的紅線,而top+bottom的長(zhǎng)度就等于字體高度.即等于|top|+|bottom|絕對(duì)值
實(shí)際繪制的時(shí)候取決于基線上一個(gè)點(diǎn)來(lái)繪制文字,而這個(gè)點(diǎn)有三種分別對(duì)應(yīng)為left,center,right如下圖
而drawText()方法中x,y坐標(biāo)所指的點(diǎn)就是上圖基線上三個(gè)點(diǎn)中的一個(gè),具體是哪一個(gè)根據(jù)paint的setTextAlign()方法設(shè)置,默認(rèn)為left
示例代碼如下
Rect rect = new Rect(100,100,500,500);//畫一個(gè)矩形 Paint rectPaint = new Paint(); rectPaint.setColor(Color.BLUE); rectPaint.setStyle(Paint.Style.FILL); canvas.drawRect(rect, rectPaint); Paint textPaint = new Paint(); textPaint.setColor(Color.WHITE); textPaint.setTextSize(50); textPaint.setStyle(Paint.Style.FILL); //該方法即為設(shè)置基線上那個(gè)點(diǎn)究竟是left,center,還是right 這里我設(shè)置為center textPaint.setTextAlign(Paint.Align.CENTER); Paint.FontMetrics fontMetrics = textPaint.getFontMetrics(); float top = fontMetrics.top;//為基線到字體上邊框的距離,即上圖中的top float bottom = fontMetrics.bottom;//為基線到字體下邊框的距離,即上圖中的bottom int baseLineY = (int) (rect.centerY() - top/2 - bottom/2);//基線中間點(diǎn)的y軸計(jì)算公式 canvas.drawText("你好世界",rect.centerX(),baseLineY,textPaint);
這里有點(diǎn)要注意textPaint.getFontMetrics()這個(gè)方法一定要在設(shè)置字體大小或者樣式等等一系列會(huì)影響字體的方法后在調(diào)用,不然獲取到的top和bottom值不準(zhǔn).
效果如下
正好是在中間的,即證明等式是沒(méi)有問(wèn)題的,再來(lái)分析這個(gè)等式是如何計(jì)算的
之所以drawText()方法中x,y指的是基線中間的那個(gè)點(diǎn),是因?yàn)?span style="color: #800000">setTextAlign(Paint.Align.Center)
那么要想在正中間顯示文字,x只要為矩形的中點(diǎn)x坐標(biāo)即可 x = rect.centerX()
要計(jì)算的就是基線中間圖上紅色點(diǎn)的y坐標(biāo)了,看圖可以發(fā)現(xiàn)紅色點(diǎn)的y為矩形中點(diǎn)黑色點(diǎn)的y坐標(biāo)+圖中黑色點(diǎn)和紅色點(diǎn)之間的距離
矩形y坐標(biāo)為 rect.centerY()
黑色點(diǎn)和紅色點(diǎn)之間的距離為相對(duì)于基線的(top+bottom)/2 - bottom
而 top是相對(duì)于基線的所以為負(fù)數(shù),所以公式為 (-top+bottom)/2 - bottom簡(jiǎn)化下為-top/2 - bottom/2
所以最后計(jì)算為rect.centerY - top/2 - bottom/2.
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Android學(xué)習(xí)之Span的使用方法詳解
這篇文章主要為大家詳細(xì)介紹了Android中各種Span類的使用方法,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)Android有一定的幫助,需要的可以參考一下2022-06-06Android TextWatcher內(nèi)容監(jiān)聽(tīng)死循環(huán)案例詳解
這篇文章主要介紹了Android TextWatcher內(nèi)容監(jiān)聽(tīng)死循環(huán)案例詳解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-08-08android車牌識(shí)別系統(tǒng)EasyPR使用詳解
這篇文章主要為大家詳細(xì)介紹了android車牌識(shí)別系統(tǒng)EasyPR使用,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-12-12Adapter模式實(shí)戰(zhàn)之重構(gòu)鴻洋集團(tuán)的Android圓形菜單建行
這篇文章主要介紹了Adapter模式實(shí)戰(zhàn)之重構(gòu)鴻洋集團(tuán)的Android圓形菜單建行的相關(guān)資料,需要的朋友可以參考下2016-03-03Android 集成Google Cast 異常問(wèn)題解析
這篇文章主要為大家介紹了Android 集成Google Cast 異常問(wèn)題解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02Android數(shù)據(jù)存儲(chǔ)幾種方式講解
在開(kāi)發(fā)過(guò)程中,數(shù)據(jù)存取是較為頻繁的,今天我們來(lái)了解下android幾種常見(jiàn)的數(shù)據(jù)存取方式。在Android中,sharePreferences是一種輕量級(jí)的數(shù)據(jù)存儲(chǔ)方式,采用鍵值對(duì)的存儲(chǔ)方式,存儲(chǔ)少量數(shù)據(jù),支持基本類型的簡(jiǎn)單數(shù)據(jù)存儲(chǔ)2022-12-12