Android -- 仿釘釘群頭像(圖文混合)

效果圖

效果圖.PNG

一個仿釘釘群組頭像顯示效果补疑,支持圖片和文字,可以任意組合情龄,非常方便迄汛,代碼量也非常少捍壤,非常適合拿來學(xué)習(xí)骤视。

繪制一個圓形圖片頭像

這里我首先新建了一個畫布,然后把畫布切割成圓形鹃觉,接下來专酗,通過Bitmap的createScaledBitmap把bitmap縮放到指定大小(這里是畫布大械辽取)祷肯,最后把bitmap繪制到畫布上,代碼如下:

        final Bitmap result = Bitmap.createBitmap(width, height, Bitmap.Config.ARGB_8888);
        Canvas canvas = new Canvas(result);

        Path mPath = new Path();
        mPath.addCircle(width/2, height/2, width/2, Path.Direction.CCW);
        canvas.clipPath(mPath); //切割畫布
        Bitmap bmp = Bitmap.createScaledBitmap(bitmap, mWidth, mHeight, false);
        canvas.drawBitmap(bmp, 0, 0, null);

這樣就可以實現(xiàn)圖中第一行第一個的效果了疗隶,是不是很簡單佑笋。

繪制半圓

接下來是第二個,它由左右兩個半圓組成斑鼻,我們看下左半圓蒋纬,按上面的方法把bitmap縮放到畫布大小,我們?nèi)≈虚g部分來展示,所用的方法是Bitmap的createBitmap(Bitmap source, int x, int y, int width, int height)蜀备,它以source為原圖关摇,創(chuàng)建新的圖片,指定起始坐標(biāo)以及新圖像的高寬碾阁。由于是取中間部分输虱,所以起始坐標(biāo)x=mWidth/4,y=0脂凶,寬度width=mWidth/2宪睹,高度height=mHeight,最后調(diào)用canvas的drawBitmap(Bitmap bitmap, float left, float top, Paint paint)進(jìn)行繪制蚕钦,如果是左半部分left=0横堡,top=0,右半部份left=mWidth / 2冠桃,top = 0命贴,代碼如下(marginWhiteWidth 為中間間隔的寬度):

       x = mWidth / 4 + marginWhiteWidth / 2;
       y = 0;
       width = mWidth / 2 - marginWhiteWidth / 2;// 中間留有1px白條
       height = mHeight;
       //左半部分
       left=0;
       top=0;
       //右半部分
       //left=mWidth / 2 + marginWhiteWidth / 2;
       //top=0;
       // 比例縮放
       Bitmap bmp = Bitmap.createScaledBitmap(bitmap, mWidth, mHeight, false);
       // 裁取中間部分(從x點裁取置頂距離)
       Bitmap dstBmp = Bitmap.createBitmap(bmp, x, y, width,  height);
       // 繪圖
       canvas.drawBitmap(dstBmp, left, top, null);

繪制四分之一圓

//接下來看第四個,繪制四分之一圓食听,把bitmap的寬高縮放到畫布的一半胸蛛,根據(jù)位置調(diào)整drawBitmap方法的left和top就可以了。

dstWidth = mWidth/2 - marginWhiteWidth / 2;
dstHeight = mHeight/2 - marginWhiteWidth / 2;
//左上
left = 0;
top = 0;
//左下
//left = 0;
//top = mHeight/2 + marginWhiteWidth / 2;
//右上
//left = mWidth/2 + marginWhiteWidth / 2;
//top = 0;
//右下
//left = mWidth/2 + marginWhiteWidth / 2;
//top = mHeight/2 + marginWhiteWidth / 2;
// 比例縮放
Bitmap bmp = Bitmap.createScaledBitmap(bitmap, dstWidth, dstHeight, false);
// 繪圖
canvas.drawBitmap(bmp, left, top, null);

繪制一個圓形文字頭像

首先給文字繪制背景

Paint textBgPaint = new Paint();
textBgPaint.setColor(Color.parseColor(bgColer));
canvas.drawRect(bgLeft, bgTop, bgRight, bgBottom, textBgPaint);

調(diào)整bgLeft, bgTop, bgRight, bgBottom的值就可以調(diào)整背景的區(qū)域樱报。
接下來繪制文字

Paint textPaint = new Paint();
textPaint.setColor(Color.WHITE);
textPaint.setTextSize(textSize);
textPaint.setStyle(Paint.Style.FILL);
//該方法即為設(shè)置基線上那個點究竟是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
x = mWidth/2;      
y = (int) (mHeight/2 - top/2 - bottom/2);//基線中間點的y軸計算公式
canvas.drawText(text, x, y, textPaint);

可以調(diào)整x葬项,y的值來調(diào)整文字的位置,具體請看源碼迹蛤。部分參考自DingDingImage,特此感謝民珍。
源碼

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市盗飒,隨后出現(xiàn)的幾起案子嚷量,更是在濱河造成了極大的恐慌,老刑警劉巖逆趣,帶你破解...
    沈念sama閱讀 211,194評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蝶溶,死亡現(xiàn)場離奇詭異,居然都是意外死亡宣渗,警方通過查閱死者的電腦和手機(jī)抖所,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,058評論 2 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來痕囱,“玉大人田轧,你說我怎么就攤上這事“盎郑” “怎么了傻粘?”我有些...
    開封第一講書人閱讀 156,780評論 0 346
  • 文/不壞的土叔 我叫張陵巷查,是天一觀的道長。 經(jīng)常有香客問我抹腿,道長岛请,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,388評論 1 283
  • 正文 為了忘掉前任警绩,我火速辦了婚禮崇败,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘肩祥。我一直安慰自己后室,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 65,430評論 5 384
  • 文/花漫 我一把揭開白布混狠。 她就那樣靜靜地躺著岸霹,像睡著了一般。 火紅的嫁衣襯著肌膚如雪将饺。 梳的紋絲不亂的頭發(fā)上贡避,一...
    開封第一講書人閱讀 49,764評論 1 290
  • 那天,我揣著相機(jī)與錄音予弧,去河邊找鬼刮吧。 笑死,一個胖子當(dāng)著我的面吹牛掖蛤,可吹牛的內(nèi)容都是我干的杀捻。 我是一名探鬼主播,決...
    沈念sama閱讀 38,907評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼蚓庭,長吁一口氣:“原來是場噩夢啊……” “哼致讥!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起器赞,我...
    開封第一講書人閱讀 37,679評論 0 266
  • 序言:老撾萬榮一對情侶失蹤垢袱,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后拳魁,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體惶桐,經(jīng)...
    沈念sama閱讀 44,122評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,459評論 2 325
  • 正文 我和宋清朗相戀三年潘懊,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片贿衍。...
    茶點故事閱讀 38,605評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡授舟,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出贸辈,到底是詐尸還是另有隱情释树,我是刑警寧澤,帶...
    沈念sama閱讀 34,270評論 4 329
  • 正文 年R本政府宣布,位于F島的核電站奢啥,受9級特大地震影響秸仙,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜桩盲,卻給世界環(huán)境...
    茶點故事閱讀 39,867評論 3 312
  • 文/蒙蒙 一寂纪、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧赌结,春花似錦捞蛋、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,734評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至量承,卻和暖如春搬设,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背撕捍。 一陣腳步聲響...
    開封第一講書人閱讀 31,961評論 1 265
  • 我被黑心中介騙來泰國打工焕梅, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人卦洽。 一個月前我還...
    沈念sama閱讀 46,297評論 2 360
  • 正文 我出身青樓贞言,卻偏偏與公主長得像,于是被迫代替她去往敵國和親阀蒂。 傳聞我的和親對象是個殘疾皇子该窗,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,472評論 2 348

推薦閱讀更多精彩內(nèi)容