public class getYuanBitmap { /** * 先画头像边缘的渐变 * */ public void JianBian(Paint paint,int j,int k){ RadialGradient gradient = new RadialGradient(j/2,k/2,j/2,new int[]{0xff5d5d5d,0xff5d5d5d,0x00ffffff},new float[]{0.f,0.8f,1.0f}, Shader.TileMode.CLAMP); paint.setShader(gradient); } /** * 转换图片成圆形 * @param bitmap 传入Bitmap对象 * @return */ public Bitmap toRoundBitmap(Bitmap bitmap) { final Paint paint = new Paint(); int width = bitmap.getWidth(); int height = bitmap.getHeight(); float roundPx; float left,top,right,bottom,dst_left,dst_top,dst_right,dst_bottom; JianBian(paint,width,height); if (width <= height) { roundPx = width / 2 ; top = 0; bottom = width; left = 0; right = width; height = width; dst_left = 0; dst_top = 0; dst_right = width; dst_bottom = width; Log.i ("111111","111111" ); } else { roundPx = height / 2 ; float clip = (width - height) / 2; left = clip; right = width - clip; top = 0; bottom = height; width = height; dst_left = 0; dst_top = 0; dst_right = height; dst_bottom = height; Log.i ("111111","22222" ); } Bitmap output = Bitmap.createBitmap(width, height, Bitmap.Config.ARGB_8888); Canvas canvas = new Canvas(output); final int color = 0xff424242; final Rect src = new Rect((int)left, (int)top, (int)right, (int)bottom); final Rect dst = new Rect((int)dst_left, (int)dst_top, (int)dst_right, (int)dst_bottom); final RectF rectF = new RectF(dst_left-5 //图片对应imageview的左边距 , dst_top-5 //图片对应imageview的上边距 , dst_right //图片对应imageview的右边距 , dst_bottom //图片对应imageview的下边距 ); paint.setAntiAlias(true); canvas.drawARGB(0, 0, 0, 0); paint.setColor(color); canvas.drawRoundRect(rectF, roundPx, roundPx, paint); paint.setXfermode(new PorterDuffXfermode ( PorterDuff.Mode.SRC_IN)); canvas.drawBitmap(bitmap, src, dst, paint); Log.i ("111111","33333" ); BaiBian ( canvas,dst_right,dst_bottom ); return output; } /** * 最后画上白边 * * * */ public void BaiBian(Canvas canvas,float j,float k){ Paint paint = new Paint(); paint.setColor(0xffffffff); paint.setStrokeWidth(2); paint.setStyle(Paint.Style.STROKE); canvas.drawCircle(j/2 //左右位置 ,k/2 //上下位置 ,j/2-2 //半径大小 ,paint); } }
Android 圆形头像 带阴影 带边界 完整代码
最新推荐文章于 2023-03-13 15:33:30 发布