自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

在Android中畫圓形圖片的幾種辦法

移動開發(fā) Android
在開發(fā)中經(jīng)常會有一些需求,比如顯示頭像,顯示一些特殊的需求,將圖片顯示成圓角或者圓形或者其他的一些形狀。但是往往我們手上的圖片或者從服務(wù)器 獲取到的圖片都是方形的。這時候就需要我們自己進(jìn)行處理,將圖片處理成所需要的形狀。正如茴香豆的的“茴”寫法大于一種,經(jīng)過我的研究,畫出特殊圖片的方 法也不是一種,我發(fā)現(xiàn)了三種,且聽我一一道來。

在開發(fā)中經(jīng)常會有一些需求,比如顯示頭像,顯示一些特殊的需求,將圖片顯示成圓角或者圓形或者其他的一些形狀。但是往往我們手上的圖片或者從服務(wù)器 獲取到的圖片都是方形的。這時候就需要我們自己進(jìn)行處理,將圖片處理成所需要的形狀。正如茴香豆的的“茴”寫法大于一種,經(jīng)過我的研究,畫出特殊圖片的方 法也不是一種,我發(fā)現(xiàn)了三種,且聽我一一道來。

使用Xfermode 兩圖相交方式

通過查找資料發(fā)現(xiàn)android中可以設(shè)置畫筆的Xfermode即相交模式,從而設(shè)置兩張圖相交之后的顯示方式,具體模式見下圖,源碼可以去android apidemo。(SRC 為我們要畫到目標(biāo)圖上的圖即原圖,DST為目標(biāo)圖)

由上圖可以看到,如果我們需要畫一個圓形的圖,可以在畫布上面先畫一個跟目標(biāo)大小一樣的圓,然后xfermode選擇SRC_IN,再講我們的頭像 或者其他圖畫上去就可以了。同樣也可以先畫我們的圖,再畫圓,不過xfermode要選擇DST_IN。兩種都可以實(shí)現(xiàn)我們需要的效果。示例代碼如下:

  1. Paint p = new Paint(); 
  2. p.setAntiAlias(true); //去鋸齒 
  3. p.setColor(Color.BLACK); 
  4. p.setStyle(Paint.Style.STROKE); 
  5. Canvas canvas = new Canvas(bitmap); //bitmap就是我們原來的圖,比如頭像 
  6. p.setXfermode(new PorterDuffXfermode(Mode.DST_IN)); //因?yàn)槲覀兿犬嬃藞D所以DST_IN 
  7. int radius = bitmap.getWidth; //假設(shè)圖片是正方形的 
  8. canvas.drawCircle(radius, radius, radius, p); //r=radius, 圓心(r,r) 

以上就是簡單的示例,根據(jù)以上的16種模式你其實(shí)還可以做出更多效果。另外,只要你給一張相交圖,那張圖形狀什么樣,我們的圖就可以顯示成什么樣。

通過裁剪畫布區(qū)域?qū)崿F(xiàn)指定形狀的圖形

Android中Canvas提供了ClipPath, ClipRect, ClipRegion 等方法來裁剪,通過Path, Rect ,Region 的不同組合,Android幾乎可以支持任意形狀的裁剪區(qū)域。因此,我們幾乎可以獲取任意形狀的區(qū)域,然后在這個區(qū)域上畫圖,就可以獲得,我們要的圖片 了,直接看示例。

  1. int radius = src.getWidth() / 2; //src為我們要畫上去的圖,跟上一個示例中的bitmap一樣。 
  2. Bitmap dest = Bitmap.createBitmap(src.getWidth(), src.getHeight(), Bitmap.Config.ARGB_8888); 
  3. Canvas c = new Canvas(dest); 
  4. Paint paint = new Paint(); 
  5. paint.setColor(Color.BLACK); 
  6. paint.setAntiAlias(true); 
  7. Path path = new Path(); 
  8. path.addCircle(radius, radius, radius, Path.Direction.CW); 
  9. c.clipPath(path); //裁剪區(qū)域 
  10. c.drawBitmap(src, 00, paint);  //把圖畫上去 

使用BitmapShader

直接先看示例

  1. int radius = src.getWidth() / 2
  2. BitmapShader bitmapShader = new BitmapShader(src, Shader.TileMode.REPEAT, 
  3. Shader.TileMode.REPEAT); 
  4. Bitmap dest = Bitmap.createBitmap(src.getWidth(), src.getHeight(), Bitmap.Config.ARGB_8888); 
  5. Canvas c = new Canvas(dest); 
  6. Paint paint = new Paint(); 
  7. paint.setAntiAlias(true); 
  8. paint.setShader(bitmapShader); 
  9. c.drawCircle(radius,radius, radius, paint); 

Shader就是畫筆的渲染器,本質(zhì)上這中方法其實(shí)是畫圓,但是渲染采用了我們的圖片,然后就可以獲得指定的形狀了。但是我覺得,這個不適合畫很復(fù) 雜的圖形,但是在內(nèi)存消耗上,應(yīng)該比***種小很多。同時呢,設(shè)置Shader.TileMode.MIRROR,還可以實(shí)現(xiàn)鏡面效果,也是極好的。

上面就是實(shí)現(xiàn)的三種方法,三種方法都可以畫很多的形狀,當(dāng)然遇到非常非常非常非常復(fù)雜的情況,我是建議使用***種,這時候可以讓美工給一張末班形狀圖,省自己去代碼繪制了。大家根據(jù)自己的需求選擇。

在github上面CustomShapeImageView就是用了我們所說的***種方法繪制。RoundedImageViewCircleImageView則使用bitmapshader完成,當(dāng)然可能還有一些其他的控件,也許還有其他的一些實(shí)現(xiàn)方法,如果你知道,可以回復(fù)告訴我^_^。

原文地址:在android中畫圓形圖片的幾種辦法

責(zé)任編輯:閆佳明 來源: blog.isming.me
相關(guān)推薦

2021-03-02 18:35:27

SVG開發(fā)空間

2011-05-30 13:15:05

PHP

2011-06-19 08:59:59

錨文本

2009-12-10 10:36:42

Visual Stud

2013-04-22 13:57:15

Android圖像特效

2018-01-16 15:42:38

Windows 10SSD磁盤

2013-08-21 11:31:21

iPhone圖片方法

2017-11-27 09:11:42

SSDceph應(yīng)用

2024-01-09 11:56:58

Go編程語言

2024-06-03 08:26:34

Android開發(fā)監(jiān)聽器

2012-09-29 13:33:16

Squid圖片存儲存儲架構(gòu)

2024-01-08 11:39:57

FlutterUI設(shè)計(jì)

2022-04-06 10:34:09

Linux元數(shù)據(jù)

2013-11-28 10:37:36

虛擬桌面環(huán)境

2012-06-26 10:35:40

Squid架構(gòu)

2024-05-28 08:23:36

Android開發(fā)文本

2017-02-06 13:31:19

Android樣式繼承關(guān)系

2010-03-03 13:24:08

連接Windows遠(yuǎn)程

2011-12-30 13:16:31

2009-07-28 16:07:40

.NET圖片快速處理
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號