• 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;
    	}


    更改后的源代码下载





  • 相关阅读:
    广陵基地输电线路实训场
    广陵基地配电网综合实训室
    广陵基地电缆实训室
    Windows Phone 9再见了!
    Windows Phone 8初学者开发—第23部分:测试并向应用商店提交
    Windows Phone 8初学者开发—第22部分:用演示图板创建卷盘的动画
    JDBC数据类型
    Java-BlockingQueue的使用
    苹果下如果安装nginx,给nginx安装markdown第三方插件
    苹果电脑包管理
  • 原文地址:https://www.cnblogs.com/yjbjingcha/p/7018529.html
Copyright © 2020-2023  润新知