android 图片圆角 遮罩_Android开发自定义ImageView控件实现圆角边框等功能

在开发中有时我们需要一个功能,或者一个控件,但是官方的又满足不了我们的需求,此时就需要我们自己实现这些功能;

下边边就是我们经常会需要的一个实现了图片的圆角,以及添加边框等功能的自定义控件;文章最后有项目源码地址

这个自定义ImageView控件实现了图片的圆角、圆形、边框等功能,同时具有按下改变颜色的效果,通过属性设置可以自定义按下的颜色,

以及颜色的透明度;还尅定义边框的颜色

Demo截图:

控件属性定义

控件代码的实现​

package net.melove.demo.chat.widget;

import android.content.Context;

import android.content.res.TypedArray;

import android.graphics.Bitmap;

import android.graphics.Canvas;

import android.graphics.Matrix;

import android.graphics.Paint;

import android.graphics.PorterDuff;

import android.graphics.PorterDuffXfermode;

import android.graphics.RectF;

import android.graphics.drawable.BitmapDrawable;

import android.graphics.drawable.ColorDrawable;

import android.graphics.drawable.Drawable;

import android.util.AttributeSet;

import android.view.MotionEvent;

import android.widget.ImageView;

import net.melove.demo.chat.R;

/**

* Created by lzan13 on 2015/4/30.

* 自定义 ImageView 控件,实现了圆角和边框,以及按下变色

*/

public class MLImageView extends ImageView {

// 图片按下的画笔

private Paint pressPaint;

// 图片的宽高

private int width;

private int height;

// 定义 Bitmap 的默认配置

private static final Bitmap.Config BITMAP_CONFIG = Bitmap.Config.ARGB_8888;

private static final int COLORDRAWABLE_DIMENSION = 1;

// 边框颜色

private int borderColor;

// 边框宽度

private int borderWidth;

// 按下的透明度

private int pressAlpha;

// 按下的颜色

private int pressColor;

// 圆角半径

private int radius;

// 图片类型(矩形,圆形)

private int shapeType;

public MLImageView(Context context) {

super(context);

init(context, null);

}

public MLImageView(Context context, AttributeSet attrs) {

super(context, attrs);

init(context, attrs);

}

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

super(context, attrs, defStyleAttr);

init(context, attrs);

}

private void init(Context context, AttributeSet attrs

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值