Paint.setXfermode(PorterDuff.Mod
2018-10-24 本文已影响0人
Air_w
目录:
1、预备:阅读本篇文章,需具备View的绘制基本知识。
2、讲解:PorterDuff.Mode https://developer.android.com/reference/android/graphics/PorterDuff.Mode
3、实战:使用PorterDuff.Mode实现圆形头像。
核心代码:
paint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_ATOP));
PorterDuff.Mode
1、SRC
PorterDuff.Mode.SRC
data:image/s3,"s3://crabby-images/e393e/e393e51fee508a6eeab0edb33a2557fc7c414e6e" alt=""
PorterDuff.Mode.SRC_OVER
data:image/s3,"s3://crabby-images/8aa2a/8aa2a673cb504428fd43b9ad370f414223f9cd3d" alt=""
PorterDuff.Mode.SRC_IN
data:image/s3,"s3://crabby-images/c099c/c099c9e28dfb9655546f3eeadf93da2c488d67a2" alt=""
PorterDuff.Mode.SRC_OUT
data:image/s3,"s3://crabby-images/f7635/f7635379ab605189c21abb5fb1b90a3768e483b0" alt=""
PorterDuff.Mode.SRC_ATOP
data:image/s3,"s3://crabby-images/6c975/6c975b36785a4e9c43fba6c0011249677ae71094" alt=""
2、Destination
PorterDuff.Mode.DST
data:image/s3,"s3://crabby-images/a4cae/a4caea9caf95745a8958f38480c4a1f72131c1fa" alt=""
PorterDuff.Mode.DST_OVER
data:image/s3,"s3://crabby-images/cd5b0/cd5b04dc0e6bb447a85bae6945873fd68868f5bd" alt=""
PorterDuff.Mode.DST_IN
data:image/s3,"s3://crabby-images/60212/6021275e463fa0968c136a6e71501e09cbe7b172" alt=""
PorterDuff.Mode.DST_OUT
data:image/s3,"s3://crabby-images/bbcd7/bbcd7cda3ad80f19f27f9f14419d7ac97d7c46da" alt=""
PorterDuff.Mode.DST_ATOP
data:image/s3,"s3://crabby-images/17d01/17d01e45789a2d510cc140c4f45e9f25a37262fb" alt=""
3、Clear
PorterDuff.Mode.CLEAR
data:image/s3,"s3://crabby-images/4138a/4138a1fe2971aeeb926287971e8339a7a4f48bd6" alt=""
3、Exclusive or
PorterDuff.Mode.XOR
data:image/s3,"s3://crabby-images/75a74/75a74e694d39062cca0c9b305429e046bb50dbca" alt=""
PorterDuff.Mode,实现圆形头像 (支持Padding、wrap_content属性)
1、核心代码
public class AirXfermodeCircleView extends ImageView {
private static final String TAG = "AirXfermodeCircleView";
private static final int MIN_SIZE_DEFAULT = 100;
private Paint mDrawablePaint;
public AirXfermodeCircleView(Context context) {
this(context, null);
}
public AirXfermodeCircleView(Context context, @Nullable AttributeSet attrs) {
this(context, attrs, 0);
}
public AirXfermodeCircleView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
this(context, attrs, defStyleAttr, 0);
}
public AirXfermodeCircleView(Context context, @Nullable AttributeSet attrs, int defStyleAttr, int defStyleRes) {
super(context, attrs, defStyleAttr, defStyleRes);
initializePaints();
}
private void initializePaints() {
mDrawablePaint = new Paint();
mDrawablePaint.setAntiAlias(true);
}
@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
super.onMeasure(widthMeasureSpec, heightMeasureSpec);
int widthMode = MeasureSpec.getMode(widthMeasureSpec);
int widthSize = MeasureSpec.getSize(widthMeasureSpec);
int heightMode = MeasureSpec.getMode(heightMeasureSpec);
int heightSize = MeasureSpec.getSize(heightMeasureSpec);
switch (widthMode) {
case MeasureSpec.AT_MOST:
widthSize = dpToPx(MIN_SIZE_DEFAULT);
break;
}
switch (heightMode) {
case MeasureSpec.AT_MOST:
heightSize = dpToPx(MIN_SIZE_DEFAULT);
break;
}
int minSize = Math.min(widthSize, heightSize);
//Update measured dimension.
setMeasuredDimension(minSize, minSize);
}
@Override
protected void onDraw(Canvas canvas) {
//Canvas circle image.
drawCircleImage(canvas);
}
/**
* Draw circle image with paint PorterDuff.
*
* @param canvas
* canvas.
*/
private void drawCircleImage(Canvas canvas) {
//Save layer with parameter.
canvas.saveLayerAlpha(getLeft(), getTop(), getRight(), getBottom(), 200);
//Get drawable source.
Drawable drawable = getDrawable();
BitmapDrawable bitmapDrawable = (BitmapDrawable) drawable;
Bitmap bitmap = bitmapDrawable.getBitmap();
//Computer circle image radius.
float radiusX = (getWidth() - getPaddingLeft() - getPaddingRight()) / 2f;
float radiusY = (getHeight() - getPaddingTop() - getPaddingBottom()) / 2f;
float radius = Math.min(radiusX, radiusY);
//Computer
Rect rectF = new Rect();
rectF.left = getLeft() + getPaddingLeft();
rectF.top = getTop() + getPaddingTop();
rectF.right = getRight() - getPaddingRight();
rectF.bottom = getBottom() - getPaddingBottom();
int targetBitmapWidth = rectF.right - rectF.left;
int targetBitmapHeight = rectF.bottom - rectF.top;
int diameter = (int) (radius * 2 + 0.5);
float circleX = getPaddingLeft() + radius;
float circleY = getPaddingTop() + radius;
Bitmap scaledBitmap = Bitmap.createScaledBitmap(bitmap, targetBitmapWidth, targetBitmapHeight, false);
/*
Draw destination bitmap.
*/
Bitmap bitmapDestination = Bitmap.createBitmap(targetBitmapWidth, targetBitmapHeight, Bitmap.Config.ARGB_8888);
Canvas canvasDestination = new Canvas(bitmapDestination);
//Draw circle.
canvasDestination.drawCircle(circleX, circleY, radius, mDrawablePaint);
//Draw destination bitmap.
canvas.drawBitmap(bitmapDestination, 0, 0, mDrawablePaint);
/*
Set paint's porterDuffMode
*/
mDrawablePaint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_IN));
/*
Draw source bitmap.
*/
canvas.drawBitmap(scaledBitmap, rectF, rectF, mDrawablePaint);
//Reset mode value.
mDrawablePaint.setXfermode(null);
//Restore.
canvas.restore();
}
private int dpToPx(int dp) {
return (int) (dp * getResources().getDisplayMetrics().density + 0.5);
}
}
data:image/s3,"s3://crabby-images/b8ea5/b8ea50f974dfef09a9e4b395b87ea81865acc9d6" alt=""
如果,您认为到这里就万事大吉了,那么很遗憾:请看下图
data:image/s3,"s3://crabby-images/0d5c5/0d5c5af984426598c73f0cc316b82dc3dda001ba" alt=""
所以,在绘制完成后,切记要加上:
Paint.setXfermode(null);
欲知后事如何,请看下篇分解
自此,结束了本篇的学习😊😊😊
如果,您还意犹未尽,请查阅作者更多文集😊😊😊