android自定义矩形框,Android中ImageCropper矩形、圆形 裁剪框的实现方法

本文详细介绍了如何通过自定义CircleHighlightView实现圆形裁剪功能。代码基于开源项目,通过重写draw方法创建圆形裁剪框,并响应用户触摸事件进行交互。关键步骤包括绘制圆形路径、裁剪画布以及处理用户操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前言

支持圆形裁剪框,裁剪后生成圆形图案。

代码基于开源项目修改,github上项目链接:https://www.easck.com/>

d8b8fc3bd86574ee74a7c2315fed1de4.png

说一下圆形裁剪实现部分:

1.UI方面,自定义CircleHighlightView继承至HighlightView(原有的矩形裁剪框实现),直接看draw方法实现

@Override

protected void draw(Canvas canvas) {

canvas.save();

Path path = new Path();

outlinePaint.setStrokeWidth( outlineWidth);

if(!hasFocus()) {//没焦点是,直接画一个黑色的矩形框

outlinePaint.setColor( Color.BLACK);

canvas.drawRect( drawRect, outlinePaint);

}

else {

Rect viewDrawingRect = new Rect();

viewContext.getDrawingRect( viewDrawingRect);

//已裁剪框drawRect,算出圆的半径

float radius = (drawRect.right - drawRect.left) / 2;

//添加一个圆形

path.addCircle( drawRect.left + radius, drawRect.top + radius, radius, Direction.CW);

outlinePaint.setColor( highlightColor);

//裁剪画布,path之外的区域,以outsidePaint填充

canvas.clipPath( path, Region.Op.DIFFERENCE);

canvas.drawRect( viewDrawingRect, outsidePaint);

canvas.restore();

//绘制圆上高亮线,这里outlinePaint定义的Paint.Style.STROKE:表示只绘制几何图形的轮廓。

canvas.drawPath( path, outlinePaint);

//当modifyMode为grow时,绘制handles,也就是那四个小圆

if(handleMode == HandleMode.Always || (handleMode == HandleMode.Changing && modifyMode == ModifyMode.Grow)) {

drawHandles( canvas);

}

}

}

这里就实现了画圆形裁剪框的操作。

2. 响应和处理用户触摸事件

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值