android xml图片圆角矩形,使用Path自定义圆角图片

简单实现圆角图片CircleView

效果:

bVVvGM?w=260&h=468

CircleImageView代码:

public class CircleImageView extends AppCompatImageView {

private Path mPath;

private RectF mRectF;

private Paint mPaint;

public CircleImageView(Context context) {

this(context, null);

}

public CircleImageView(Context context, AttributeSet attrs) {

this(context, attrs, 0);

}

public CircleImageView(Context context, AttributeSet attrs, int defStyleAttr) {

super(context, attrs, defStyleAttr);

init();

}

private void init() {

mPaint = new Paint(Paint.ANTI_ALIAS_FLAG);

mPaint.setColor(Color.RED);

mPaint.setStyle(Paint.Style.STROKE);

mPaint.setStrokeWidth(15);

mPath = new Path();

}

@Override

protected void onDraw(Canvas canvas) {

//设置外框的矩形区域,不可再init()初始化,构造器中width和height还未确定,可在onMesure()中获取并设置

mRectF = new RectF(0,0, getWidth(),getHeight());

//path划出一个圆角矩形,容纳图片,图片矩形区域设置比红色外框小,否则会覆盖住外框,随意控制

mPath.addRoundRect(new RectF(10, 10, mRectF.right-10,mRectF.bottom-10), 50, 50, Path.Direction.CW);

canvas.drawRoundRect(mRectF, 50, 50, mPaint); //画出红色外框圆角矩形

canvas.clipPath(mPath);//将canvas裁剪到path设定的区域,往后的绘制都只能在此区域中,

//这一句应该放在canvas.clipPath(path)之后,canvas.clipPath(path)只对裁剪之后的绘制起作用,

// 这个方法在ImageView中会画出xml设置的Drawable,落在刚才设置的path中

super.onDraw(canvas);

}

}

整个原理就是用Path划出一个圆角矩形区域,调用super.onDraw(canvas)就可以让Drawable 落在那个区域。

使用,xml:

xmlns:app="http://schemas.android.com/apk/res-auto"

xmlns:tools="http://schemas.android.com/tools"

android:layout_width="match_parent"

android:layout_height="match_parent"

tools:context="com.example.why.traing2.MainActivity">

android:id="@+id/img_circle"

android:layout_width="200dp"

android:layout_height="200dp"

android:src="@drawable/gakki"

android:scaleType="centerCrop"

app:layout_constraintTop_toTopOf="parent"

android:layout_marginTop="8dp"

app:layout_constraintBottom_toBottomOf="parent"

android:layout_marginBottom="8dp"

android:layout_marginLeft="8dp"

app:layout_constraintLeft_toLeftOf="parent"

app:layout_constraintVertical_bias="0.501"

android:layout_marginRight="8dp"

app:layout_constraintRight_toRightOf="parent"

/>

Activivty:

public class MainActivity extends AppCompatActivity {

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

CircleImageView circleImageView = (CircleImageView)findViewById(R.id.img_circle);

}

}

看了些参考资料,发现上篇写错了,发现思路比较简单的,记录下。也可以用Shader, Xfermode实现,参考:https://enggm.wordpxress.com/...

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以通过以下步骤来实现: 1. 创建一个自定义的 LinearLayout 类,并继承 LinearLayout。 2. 在自定义 LinearLayout 类的构造方法中,调用 setWillNotDraw(false) 方法,以允许绘制自定义视图。 3. 重写 onDraw(Canvas canvas) 方法,在其中绘制矩形水印图片。可以使用 Bitmap 和 Canvas 组合来绘制图片。 4. 在 onDraw() 方法中,调用 super.onDraw(canvas) 方法,以便在绘制自定义视图之后绘制子视图。 5. 在自定义 LinearLayout 类的 onMeasure(int widthMeasureSpec, int heightMeasureSpec) 方法中,设置 LinearLayout 的宽度和高度,以确保矩形水印图片的边角是圆形的。可以使用 MeasureSpec.getSize() 和 MeasureSpec.getMode() 方法来获取宽度和高度。 以下是示例代码: ``` public class RoundedLinearLayout extends LinearLayout { private Bitmap watermarkBitmap; public RoundedLinearLayout(Context context) { super(context); setWillNotDraw(false); } public RoundedLinearLayout(Context context, AttributeSet attrs) { super(context, attrs); setWillNotDraw(false); } public RoundedLinearLayout(Context context, AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); setWillNotDraw(false); } @Override protected void onDraw(Canvas canvas) { super.onDraw(canvas); if (watermarkBitmap != null) { int bitmapWidth = watermarkBitmap.getWidth(); int bitmapHeight = watermarkBitmap.getHeight(); // 获取 LinearLayout 的宽度和高度 int widthSpec = MeasureSpec.makeMeasureSpec(getWidth(), MeasureSpec.EXACTLY); int heightSpec = MeasureSpec.makeMeasureSpec(getHeight(), MeasureSpec.EXACTLY); // 创建 Canvas 对象 Canvas watermarkCanvas = new Canvas(watermarkBitmap); // 创建矩形对象 RectF rectF = new RectF(0, 0, bitmapWidth, bitmapHeight); // 创建画笔对象 Paint paint = new Paint(); paint.setAntiAlias(true); paint.setColor(Color.WHITE); // 绘制圆角矩形 watermarkCanvas.drawRoundRect(rectF, 60, 60, paint); // 在 canvas 上绘制矩形水印图片 canvas.drawBitmap(watermarkBitmap, null, new Rect(0, 0, getWidth(), getHeight()), null); } } @Override protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { super.onMeasure(widthMeasureSpec, heightMeasureSpec); // 获取 LinearLayout 的宽度和高度 int width = MeasureSpec.getSize(widthMeasureSpec); int height = MeasureSpec.getSize(heightMeasureSpec); // 设置 LinearLayout 的宽度和高度 setMeasuredDimension(width, height); // 创建 Bitmap 对象 watermarkBitmap = Bitmap.createBitmap(width, height, Bitmap.Config.ARGB_8888); } } ``` 你可以在 XML 布局文件中使用自定义 LinearLayout 类,如下所示: ``` <com.example.RoundedLinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="vertical"> <!-- 添加子视图 --> </com.example.RoundedLinearLayout> ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值