public class DrawableUtils {
/**
* 将图片的四角圆弧化
*
* @param bitmap 原图
* @param roundPixels 弧度
* @return
*/
public static Bitmap getRoundCornerImage(Bitmap bitmap, int roundPixels, int roundType) {
int width = bitmap.getWidth();
int height = bitmap.getHeight();
Path path = checkRect(width, height, roundPixels, roundType);
Bitmap roundRoundImage = Bitmap.createBitmap(width, height, Bitmap.Config.ARGB_8888);
Canvas canvas = new Canvas(roundRoundImage);
Paint paint = new Paint();
paint.setAntiAlias(true);// 抗锯齿
paint.setFilterBitmap(true);// 抗锯齿
paint.setColor(0xFF000000);
canvas.drawPath(path, paint);
paint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_IN));//设置相交模式
canvas.drawBitmap(bitmap, 0, 0, paint);
return roundRoundImage;
}
public static Path checkRect(int width, int height, int roundPixels, int roundType) {
Path path = new Path();
RectF rect = new RectF(0, 0, width, height);
path.addRoundRect(rect, roundPixels, roundPixels, Path.Direction.CCW);
if ((roundType & ROUND_LEFT_TOP) == 0) {
path.addRect(0, 0, roundPixels, roundPixels, Path.Direction.CCW);
}
if ((roundType & ROUND_RIGHT_TOP) == 0) {
path.addRect(width - roundPixels, 0, width, roundPixels, Path.Direction.CCW);
}
if ((roundType & ROUND_LEFT_BOTTOM) == 0) {
path.addRect(0, height - roundPixels, roundPixels, height, Path.Direction.CCW);
}
if ((roundType & ROUND_RIGHT_BOTTOM) == 0) {
path.addRect(width - roundPixels, height - roundPixels, width, height, Path.Direction.CCW);
}
return path;
}
public static final int ROUND_LEFT_TOP = 8;
public static final int ROUND_RIGHT_TOP = 4;
public static final int ROUND_LEFT_BOTTOM = 2;
public static final int ROUND_RIGHT_BOTTOM = 1;
}
用int的低位来表示各种状态:
- 1000 -> 8 - > 左上圆
- 0100 -> 6 - > 右上圆
- 0010 -> 4 - > 左下圆
- 0001 -> 1 - > 右下圆
1.创建一个path,然后add一个圆角,
2.通过是否有圆角来决定要不要覆盖圆角的位置
3.通过canvas.drawPath圆路径
data:image/s3,"s3://crabby-images/310b3/310b3b0f2dccd8810b95a4ecf4f4d92cb31eb97c" alt=""
data:image/s3,"s3://crabby-images/a9e9f/a9e9f815684bc185a55128129c3e405e153b1aff" alt=""
data:image/s3,"s3://crabby-images/eb728/eb72878e0fca61e9c206728664be0aa3e76b791a" alt=""
data:image/s3,"s3://crabby-images/17616/176165e76a57908e8d3f1e7ad1c8320187c097b4" alt=""
data:image/s3,"s3://crabby-images/4e069/4e069ba4a589803a0c08b58c6912348620c26b9d" alt=""
data:image/s3,"s3://crabby-images/7a445/7a4455a034c721c011ecdcf0197b5f7932691f03" alt=""
data:image/s3,"s3://crabby-images/b8ec9/b8ec9f62aae32adf6583ef48a2ca0461c990c798" alt=""
data:image/s3,"s3://crabby-images/dedbd/dedbd951b9e59144efb1d002f2cff7de45a999b9" alt=""
data:image/s3,"s3://crabby-images/4c427/4c4276f56215188928df6f57a17f44540ccafc62" alt=""
data:image/s3,"s3://crabby-images/6ffa4/6ffa484be8c6f7488d97ac1920735290eb72e47a" alt=""
data:image/s3,"s3://crabby-images/b07dc/b07dc99c9bd25b288305145e48eb75a38a4d7874" alt=""
data:image/s3,"s3://crabby-images/ad532/ad5326325a51410591921dfc8e731f8da7e8df24" alt=""
data:image/s3,"s3://crabby-images/34114/34114f9738416a1e640c8f69122e7370db602af3" alt=""
data:image/s3,"s3://crabby-images/455f2/455f219fef5f0ab576a226e0db160001fd21ad86" alt=""
data:image/s3,"s3://crabby-images/7255d/7255dc89c2a015037a6e8260e49432bfac748b2e" alt=""
data:image/s3,"s3://crabby-images/bdec5/bdec57fef10e3381b92899bba59c7c4268bb8e22" alt=""
网友评论