美文网首页
图片处理之贴纸(水印)

图片处理之贴纸(水印)

作者: 满嘴胡言 | 来源:发表于2016-06-27 23:51 被阅读286次

一直想对之前做过的一款图片社交软件cos酱(类似in nice)的代码进行梳理,但是由于时间的关系拖到今天才开始这个工作。
在项目中,主要对照片裁剪、旋转、翻转(在之前的文章有提到过)、贴纸、滤镜、文字、边框、标签等功能。

如何添加贴纸

  1. 自定义WaterMarkView;
  2. 移动、缩放贴纸(用户的操作行为);
  3. 合成图片。

自定义WaterMarkView

具体如下图

示例
有图片中我们可以看到,贴纸由3部分组成(主体内容、删除按钮、缩放按钮)。
所以在ondraw中
canvas.drawBitmap(mBitmap, matrix, paint); mPath.reset(); mPath.moveTo(mLTPoint.x,mLTPoint.y); mPath.lineTo(mRTPoint.x, mRTPoint.y); mPath.lineTo(mRBPoint.x, mRBPoint.y); mPath.lineTo(mLBPoint.x, mLBPoint.y); mPath.lineTo(mLTPoint.x, mLTPoint.y); mPath.lineTo(mRTPoint.x, mRTPoint.y); canvas.drawPath(mPath, mPaint);//画旋转, 缩放图标controlDrawable.setBounds(mControlPoint.x - mDrawableWidth / 2, mControlPoint.y - mDrawableHeight / 2, mControlPoint.x + mDrawableWidth / 2, mControlPoint.y + mDrawableHeight/2); controlDrawable.draw(canvas); removeDrawable.setBounds(mremovePoint.x - mRemoveDrawableWidth / 2, mremovePoint.y - mRemoveDrawableHeight / 2, mremovePoint.x + mRemoveDrawableWidth / 2, mremovePoint.y + mRemoveDrawableHeight / 2); removeDrawable.draw(canvas);

然后结合GestureDetector和onTouchEvent进行缩放、移动、删除操作。具体代码如下:
switch (event.getAction() & MotionEvent.ACTION_MASK) { case MotionEvent.ACTION_DOWN: if (!isEditable) { //取消其余贴纸的编辑状态,只有一个处于编辑状态 Bundle bundle = new Bundle(); bundle.putSerializable("selectWaterMarkView", this); EventBus.getEventBus().post(new BasePostEvent(CosCameraConstants.WATER_MARK_EDITSTATE_CANCLE, bundle)); //设置本身被选中 setEditState(true); } mPreMovePointF.set(event.getX() + mViewPaddingLeft, event.getY() + mViewPaddingTop); mStatus = JudgeStatus(event.getX(), event.getY()); break; case MotionEvent.ACTION_UP: mStatus = STATUS_INIT; WaterMarkClicked(event.getX(), event.getY()); break; case MotionEvent.ACTION_MOVE: mCurMovePointF.set(event.getX() + mViewPaddingLeft, event.getY() + mViewPaddingTop); if (mStatus == STATUS_ROTATE_ZOOM) { float scale = 1f; int halfBitmapWidth = mBitmap.getWidth() / 2; int halfBitmapHeight = mBitmap.getHeight() / 2; //图片某个点到图片中心的距离 float bitmapToCenterDistance = FloatMath.sqrt(halfBitmapWidth * halfBitmapWidth + halfBitmapHeight * halfBitmapHeight); //移动的点到图片中心的距离 float moveToCenterDistance = distance4PointF(mCenterPoint, mCurMovePointF); //计算缩放比例 scale = moveToCenterDistance / bitmapToCenterDistance; //缩放比例的界限判断 if (scale <= MIN_SCALE) { scale = MIN_SCALE; } else if (scale >= MAX_SCALE) { scale = MAX_SCALE; } // 角度 double a = distance4PointF(mCenterPoint, mPreMovePointF); double b = distance4PointF(mPreMovePointF, mCurMovePointF); double c = distance4PointF(mCenterPoint, mCurMovePointF); double cosb = (a * a + c * c - b * b) / (2 * a * c); if (cosb >= 1) { cosb = 1f; } double radian = Math.acos(cosb); float newDegree = (float) radianToDegree(radian); //center -> proMove的向量, 我们使用PointF来实现 PointF centerToProMove = new PointF((mPreMovePointF.x - mCenterPoint.x), (mPreMovePointF.y - mCenterPoint.y)); //center -> curMove 的向量 PointF centerToCurMove = new PointF((mCurMovePointF.x - mCenterPoint.x), (mCurMovePointF.y - mCenterPoint.y)); //向量叉乘结果, 如果结果为负数, 表示为逆时针, 结果为正数表示顺时针 float result = centerToProMove.x * centerToCurMove.y - centerToProMove.y * centerToCurMove.x; if (result < 0) { newDegree = -newDegree; } mDegree = mDegree + newDegree; mScale = scale; transformDraw(); } else if (mStatus == STATUS_REMOVE) { this.mOnRemoveWaterListener.onRemoveClick(this); } else if (mStatus == STATUS_DRAG) { // 修改中心点 mCenterPoint.x += mCurMovePointF.x - mPreMovePointF.x; mCenterPoint.y += mCurMovePointF.y - mPreMovePointF.y; adjustLayout(); } mPreMovePointF.set(mCurMovePointF); break; }
重要方法transformDraw()介绍
/** * 设置Matrix, 强制刷新 */ public void transformDraw(){ int bitmapWidth = (int)(mBitmap.getWidth() * mScale); int bitmapHeight = (int)(mBitmap.getHeight()* mScale); computeRect(-framePadding, -framePadding, bitmapWidth + framePadding, bitmapHeight + framePadding, mDegree); //设置缩放比例 matrix.setScale(mScale, mScale); //绕着图片中心进行旋转 matrix.postRotate(mDegree % 360, bitmapWidth/2, bitmapHeight/2); //设置画该图片的起始点 matrix.postTranslate(offsetX + mDrawableWidth/2, offsetY + mDrawableHeight/2); invalidate(); }
重要方法transformDraw()介绍
/** * 调整View的大小,位置 */ public void adjustLayout(){ int actualWidth = mViewWidth + mDrawableWidth; int actualHeight = mViewHeight + mDrawableHeight; int newPaddingLeft = (int) (mCenterPoint.x - actualWidth /2); int newPaddingTop = (int) (mCenterPoint.y - actualHeight/2); if(mViewPaddingLeft != newPaddingLeft || mViewPaddingTop != newPaddingTop){ mViewPaddingLeft = newPaddingLeft; mViewPaddingTop = newPaddingTop; layout(newPaddingLeft, newPaddingTop, newPaddingLeft + actualWidth, newPaddingTop + actualHeight); } }

合成图片

很笨挫的办法,通过view生成图片:
Canvas canvas = new Canvas(new_bitmap); photo_area_rl.draw(canvas);

相关文章

  • 图片处理之贴纸(水印)

    一直想对之前做过的一款图片社交软件cos酱(类似in nice)的代码进行梳理,但是由于时间的关系拖到今天才开始这...

  • 对于文章图片中水印的问题

    处理图片水印:下面的函数可以处理局部的水印,详细请看函数文档该函数适合处理位置固定的水印. 在水印位置覆盖新的水印...

  • 怎样去掉日常(批量)图片和视频中的水印

    这次小咖不仅要教大家如何快速去掉图片水印,还要教大家如何批量处理掉视频中的水印!!真的超快超好用! 图片水印处理 ...

  • 柠檬水印助手app技术服务支持

    柠檬水印助手是一块好用的水印处理软件,可以视频图片去水印,加水印。

  • 微商必备工具 做微商这些少不了!

    第一:微商水印相机 1:图片处理(水印、二维码、海报、拼图), 2:视频处理(视频拼图、视频水印、视频海报)、 3...

  • iOS 图片处理

    本文主要列出简单的图片处理代码,如:压缩图形大小,裁剪图片,添加文字水印,添加图片水印,压缩图片大小并保存。 本来...

  • 超实用的图片压缩神器推荐,再也不用求人啦!

    上期给大家推荐的图片去水印软件:《超厉害的图片去水印黑科技,用起来!》,今天又来一批关于处理图片使用的工具:图片压...

  • java 图片水印处理

    1.实现水印效果首先要获取上传的图片并将其保存到指定目录下。作为原图 2.将图片加载到内存当中通过ImageIO....

  • JAVA-图片加水印功能的实现

    图片加水印功能的实现 最近公司需要实现一个图片加水印的功能。 简单看了下需求,因为之前做截图工具的时候,对图片处理...

  • linux下PDF及表格处理软件

    pdftk 批量给PDF加水印 : ImageMagick 图片处理 转换图片格式 :#http://el...

网友评论

      本文标题:图片处理之贴纸(水印)

      本文链接:https://www.haomeiwen.com/subject/btxtjttx.html