圆形切图

原创 2017年01月03日 01:23:37

方案1 用的时候直接把imageView换成这个就可以啦

import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.Canvas;
import android.graphics.Paint;
import android.graphics.PorterDuff;
import android.graphics.PorterDuffXfermode;
import android.graphics.Rect;
import android.graphics.drawable.BitmapDrawable;
import android.graphics.drawable.Drawable;
import android.util.AttributeSet;
import android.widget.ImageView;

public class XCRoundImageView extends ImageView
{
    private Paint paint ; public XCRoundImageView(Context context) { this(context,null);

}
    public XCRoundImageView(Context context, AttributeSet attrs)
    {
        this(context, attrs,0);
    }

    public XCRoundImageView(Context context, AttributeSet attrs, int defStyle)
    {
        super(context, attrs, defStyle);
        paint = new Paint();

    } /** * 绘制圆形图片
 * @author caizhiming */ @Override protected void onDraw(Canvas canvas) {

    Drawable drawable = getDrawable(); if (null != drawable) {
        Bitmap bitmap = ((BitmapDrawable) drawable).getBitmap();
        Bitmap b = getCircleBitmap(bitmap, 14); final Rect rectSrc = new Rect(0, 0, b.getWidth(), b.getHeight()); final Rect rectDest = new Rect(0,0,getWidth(),getHeight());
        paint.reset();
        canvas.drawBitmap(b, rectSrc, rectDest, paint);

    } else { super.onDraw(canvas);
    }
} /** * 获取圆形图片方法
 * @param bitmap
 * @param pixels
 * @return Bitmap
 * @author caizhiming */ private Bitmap getCircleBitmap(Bitmap bitmap, int pixels) {
    Bitmap output = Bitmap.createBitmap(bitmap.getWidth(),
            bitmap.getHeight(), Bitmap.Config.ARGB_8888);
    Canvas canvas = new Canvas(output); final int color = 0xff424242; final Rect rect = new Rect(0, 0, bitmap.getWidth(), bitmap.getHeight());
    paint.setAntiAlias(true);
    canvas.drawARGB(0, 0, 0, 0);
    paint.setColor(color); int x = bitmap.getWidth();

    canvas.drawCircle(x / 2, x / 2, x / 2, paint);
    paint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_IN));
    canvas.drawBitmap(bitmap, rect, rect, paint); return output;

}}

方案2 
    compile 'de.hdodenhof:circleimageview:2.1.0'
布局中这么用
 <de.hdodenhof.circleimageview.CircleImageView
            xmlns:app="http://schemas.android.com/apk/res-auto"
            android:id="@+id/civ_img"
            android:layout_width="45dp"
            android:layout_height="45dp"
            android:layout_gravity="center_vertical"
            app:civ_border_width="1dp"
            app:civ_border_color="#FF000000"/>

代码中 这么用
        @Bind(R.id.civ_img)
        CircleImageView civImg;




版权声明:落叶的一生,难道只是为了归根么? 举报

相关文章推荐

Android 自定义View实现圆形切图的效果

使用自定义View实现圆形ImageView的效果 目前圆形边框还需要调整,这里有点问题实现思路使用一个Paint,将得到的Bitmap设置成paint的Shader,设置完成后,使用Matrix调...
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)