Android 实现最新版QQ图像裁剪功能

这是根据翔神那篇高仿微信图像截取改的  可以先去看   Android 高仿微信头像截取 打造不一样的自定义控件 这篇文章。

目前还有个小问题,就是截取成圆形图片之后 会有黑色的边框填充。不知道怎么解决。知道怎么解决的大神麻烦告知一声。




修改ClipImageBorderView


	@Override
	protected void onDraw(Canvas canvas)
	{
		super.onDraw(canvas);

		// // 计算矩形区域的宽度
		// mWidth = getWidth() - 2 * mHorizontalPadding;
		// // 计算距离屏幕垂直边界 的边距
		// mVerticalPadding = (getHeight() - mWidth) / 2;
		// mPaint.setColor(Color.parseColor("#aa000000"));
		// mPaint.setStyle(Style.FILL);
		// // 绘制左边1
		// canvas.drawRect(0, 0, mHorizontalPadding, getHeight(), mPaint);
		// // 绘制右边2
		// canvas.drawRect(getWidth() - mHorizontalPadding, 0, getWidth(),
		// getHeight(), mPaint);
		// // 绘制上边3
		// canvas.drawRect(mHorizontalPadding, 0, getWidth() -
		// mHorizontalPadding, mVerticalPadding, mPaint);
		// // 绘制下边4
		// canvas.drawRect(mHorizontalPadding, getHeight() - mVerticalPadding,
		// getWidth() - mHorizontalPadding, getHeight(), mPaint);
		// // 绘制外边框
		// mPaint.setColor(mBorderColor);
		// mPaint.setStrokeWidth(mBorderWidth);
		// mPaint.setStyle(Style.STROKE);
		// canvas.drawRect(mHorizontalPadding, mVerticalPadding, getWidth() -
		// mHorizontalPadding, getHeight() - mVerticalPadding, mPaint);

		if (rf == null || rf.isEmpty())
		{
			r = new Rect(0, 0, getWidth(), getHeight());
			rf = new RectF(r);
		}

		mPaint.setStyle(Style.STROKE);

		// 在imageview上面画入背景和 圆形
		int sc = canvas.saveLayer(rf, null, Canvas.MATRIX_SAVE_FLAG | Canvas.CLIP_SAVE_FLAG | Canvas.HAS_ALPHA_LAYER_SAVE_FLAG | Canvas.FULL_COLOR_LAYER_SAVE_FLAG | Canvas.CLIP_TO_LAYER_SAVE_FLAG | Canvas.ALL_SAVE_FLAG);
		mPaint.setColor(Color.parseColor("#aa000000"));
		mPaint.setStyle(Style.FILL);
		canvas.drawRect(r, mPaint);
		mPaint.setXfermode(cur_xfermode);

		// mPaint.setStyle(Style.STROKE);
		// 绘制圆形
		canvas.drawCircle(getWidth() / 2, getHeight() / 2, mRadius, mPaint);
        // 绘制边框
		canvas.drawCircle(getWidth() / 2, getHeight() / 2, mRadius, mBoderPaint);
		canvas.restoreToCount(sc);
		mPaint.setXfermode(null);

	}


修改 ClipZoomImageView


public Bitmap onClip()
	{
		// 获取imageview的bitmap
	
		Paint paint = new Paint();

		invalidate();
		setDrawingCacheEnabled(true);
		Bitmap bitmap = getDrawingCache().copy(getDrawingCache().getConfig(), false);
		setDrawingCacheEnabled(false);
		// 创建你要截取的位图 
		Bitmap bitmap2 = Bitmap.createBitmap(2 * mRadius, 2 * mRadius, Config.ARGB_8888);
		Canvas canvas = new Canvas(bitmap2);

		canvas.drawRoundRect(new RectF(0, 0, 2 * mRadius, 2 * mRadius), mRadius, mRadius, paint);
		paint.setXfermode(new PorterDuffXfermode(Mode.SRC_IN));
		RectF dst = new RectF(-bitmap.getWidth() / 2 + mRadius, -getHeight() / 2 + mRadius, bitmap.getWidth() - bitmap.getWidth() / 2 + mRadius, getHeight() - getHeight() / 2 + mRadius);
		canvas.drawBitmap(bitmap, null, dst, paint);

		return bitmap2;
	}


更改后的源码下载





  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值