两种方式实现图形图片

本文介绍两种实现图形图片的方法。
1.通过裁剪bitmap, 使用PorterDuffXfermode, 可以参考这篇博客
http://blog.csdn.net/edisonlg/article/details/7084977
2.通过设置渲染器 BitmapShader, 使用一张图片创建一支具有图像填充功能的画笔

具体代码如下

public class CircleImageView extends ImageView {
    private Bitmap srcBitmap;
    private Rect rect;
    private Paint paint;
    private BitmapShader mBitmapShader;
    private int mRadius;
    private Matrix mMatrix;

    public CircleImageView(Context context) {
        super(context);
        init();
    }


    public CircleImageView(Context context, AttributeSet attrs) {
        super(context, attrs);
        init();
    }

    public CircleImageView(Context context, AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
        init();
    }


    /**
     * 初始化变量
     */
    private void init() {
        paint = new Paint();
        paint.setAntiAlias(true);
        srcBitmap = ((BitmapDrawable) getDrawable()).getBitmap();
        mMatrix = new Matrix();
    }

    @Override
    protected void onSizeChanged(int w, int h, int oldw, int oldh) {
        super.onSizeChanged(w, h, oldw, oldh);

        if (getWidth() > 0 && getHeight() > 0) {
            rect = new Rect(0, 0, getWidth(), getHeight());
            int mWidth = Math.min(getMeasuredWidth(), getMeasuredHeight());
            mRadius = mWidth / 2;

            //计算缩放比例
      int bSize = Math.min(srcBitmap.getWidth(), srcBitmap.getHeight());
            float scale = mWidth * 1.0f / bSize;
            mMatrix.setScale(scale, scale);

        }
    }

    @Override
    protected void onDraw(Canvas canvas) {


        // 方式1.通过裁剪bitmap
      //  canvas.drawBitmap(createCricleBitmap(srcBitmap), rect, rect, null);


        //方式2.通过设置渲染器
        mBitmapShader = new BitmapShader(srcBitmap, Shader.TileMode.CLAMP, Shader.TileMode.CLAMP);

    // 设置缩放
     mBitmapShader.setLocalMatrix(mMatrix);
        paint.setShader(mBitmapShader);
        canvas.drawCircle(mRadius,
                mRadius,
                mRadius,
                paint);


    }

    /**
     * 获取裁剪后的圆形图片
     *
     * @param bitmap
     * @return
     */
    private Bitmap createCricleBitmap(Bitmap bitmap) {
        Bitmap outBitmap = Bitmap.createBitmap(bitmap.getWidth(), bitmap.getHeight(),
                Bitmap.Config.ARGB_8888);
        Canvas canvas = new Canvas(outBitmap);
        canvas.drawCircle(mRadius,
                mRadius,
                mRadius,
                paint);
        paint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_IN));
        canvas.drawBitmap(bitmap, mMatrix, paint);
        return outBitmap;

    }

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值