前段時間對Android的paint和canvas做了深入的瞭解,針對於開發過程中遇到的頭像幾乎都是圓形的問題,抽空寫了個demo,,廢話不多說,直接上代碼。
首先自定義一個view,繼承imageview。關於PorterDuff及Xfermode詳解可點擊鏈接,代碼中就不做詳細解釋
<span style="font-size:18px;color:#009900;"><span style="color:#009900;">package com.example.text;
import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.Canvas;
import android.graphics.Paint;
import android.graphics.PorterDuff;
import android.graphics.PorterDuffXfermode;
import android.graphics.Xfermode;
import android.graphics.drawable.Drawable;
import android.util.AttributeSet;
import android.widget.ImageView;
public abstract class MaskedImage extends ImageView{
private static final Xfermode MASK_XFERMODE;
private Bitmap mask;
private Paint paint;
static {
PorterDuff.Mode localMode = PorterDuff.Mode.DST_IN; //取兩層繪製交集。顯示上層。
MASK_XFERMODE = new PorterDuffXfermode(localMode);
}
public MaskedImage(Context paramContext) {
super(paramContext);
}
public MaskedImage(Context paramContext, AttributeSet paramAttributeSet) {
super(paramContext, paramAttributeSet);
}
public MaskedImage(Context paramContext, AttributeSet paramAttributeSet, int paramInt) {
super(paramContext, paramAttributeSet, paramInt);
}
public abstract Bitmap createMask();
protected void onDraw(Canvas paramCanvas) {
Drawable localDrawable = getDrawable();
if (localDrawable == null)
return;
try {
if (this.paint == null) {
Paint localPaint1 = new Paint();
this.paint = localPaint1;
this.paint.setFilterBitmap(false);
Paint localPaint2 = this.paint;
Xfermode localXfermode1 = MASK_XFERMODE;
@SuppressWarnings("unused")
Xfermode localXfermode2 = localPaint2.setXfermode(localXfermode1);
}
float f1 = getWidth();
float f2 = getHeight();
int i = paramCanvas.saveLayer(0.0F, 0.0F, f1, f2, null, 31);
int j = getWidth();
int k = getHeight();
localDrawable.setBounds(0, 0, j, k);
localDrawable.draw(paramCanvas);
if ((this.mask == null) || (this.mask.isRecycled())) {
Bitmap localBitmap1 = createMask();
this.mask = localBitmap1;
}
Bitmap localBitmap2 = this.mask;
Paint localPaint3 = this.paint;
paramCanvas.drawBitmap(localBitmap2, 0.0F, 0.0F, localPaint3);
paramCanvas.restoreToCount(i);
return;
} catch (Exception localException) {
StringBuilder localStringBuilder = new StringBuilder()
.append("Attempting to draw with recycled bitmap. View ID = ");
System.out.println("localStringBuilder=="+localStringBuilder);
}
}
}</span></span>
然後再自定義一個類,繼承上面自定義的MaskedImage。關於paint和canvas的詳解點擊打開鏈接
<span style="font-size:18px;color:#009900;"><span style="color:#009900;">package com.example.text;
import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.Canvas;
import android.graphics.Paint;
import android.graphics.RectF;
import android.util.AttributeSet;
public class CircularImage extends MaskedImage{
public CircularImage(Context paramContext) {
super(paramContext);
// TODO Auto-generated constructor stub
}
public CircularImage(Context paramContext, AttributeSet paramAttributeSet) {
super(paramContext, paramAttributeSet);
}
public CircularImage(Context paramContext, AttributeSet paramAttributeSet, int paramInt) {
super(paramContext, paramAttributeSet, paramInt);
}
@Override
public Bitmap createMask() {
// TODO Auto-generated method stub
int i = getWidth();
int j = getHeight();
Bitmap.Config localConfig = Bitmap.Config.ARGB_8888; //Bitmap.Config是圖片的質量參數,工四種,常用ARGB_8888(ALPHA_8,ARGB_4444,ARGB_8888,RGB_565)
Bitmap localBitmap = Bitmap.createBitmap(i, j, localConfig); //剪裁圖片
Canvas localCanvas = new Canvas(localBitmap); //畫布
Paint localPaint = new Paint(1); //畫筆
localPaint.setColor(-16777216);
float f1 = getWidth();
float f2 = getHeight();
RectF localRectF = new RectF(0.0F, 0.0F, f1, f2); //畫矩形
localCanvas.drawOval(localRectF, localPaint);
return localBitmap; }
}</span></span>
到這自定義的view就算完成了,在xml佈局中引用就可以。
<span style="font-size:18px;color:#009900;"><span style="color:#009900;"><RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center" >
<com.example.text.CircularImage
android:id="@+id/cover_user_photo"
android:layout_width="74.0dip"
android:layout_height="74.0dip"
/>
</RelativeLayout> </span></span>
MainActivity的代碼。
<span style="font-size:18px;color:#009900;"><span style="color:#009900;">public class MainActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
CircularImage cover_user_photo = (CircularImage) findViewById(R.id.cover_user_photo);
cover_user_photo.setImageResource(R.drawable.face);
}
}</span></span>
效果圖如下: