调整大小的ImageView上的圆角

时间:2017-08-22 13:20:24

标签: java android android-layout imageview

我正在尝试在ImageView上转角,如果将layoutParams设置为WRAP_CONTENT,但是由于它们的大小调整(因为它们设置为MATCH_PARENT),这可以正常工作,我可能需要调整一些东西

Canvas / ImageView扩展类:

import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Path;
import android.graphics.RectF;
import android.util.AttributeSet;
import android.widget.ImageView;

public class CustomImageView extends ImageView {
    public static float radius = 18.0f;

    public CustomImageView(Context context) {
        super(context);
    }

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

    public CustomImageView(Context context, AttributeSet attrs, int defStyle) {
        super(context, attrs, defStyle);
    }

    @Override
    protected void onDraw(Canvas canvas) {
        //float radius = 36.0f;
        Path clipPath = new Path();
        RectF rect = new RectF(0, 0, this.getWidth(), this.getHeight());
        clipPath.addRoundRect(rect, radius, radius, Path.Direction.CW);
        canvas.clipPath(clipPath);
        super.onDraw(canvas);
    }
}

活动类:

 @Override
 protected void onCreate(Bundle savedInstanceState) {
   super.onCreate(savedInstanceState);
   setContentView(R.layout.activity_gameplay);
   RelativeLayout gameplayRelativeLayoutImages = 
   (RelativeLayout)findViewById(R.id.gameplay_relative_layout_images);

   ImageView part1= new CustomImageView(this);
   part1.setImageResource(R.drawable.picture1);
   part1.setLayoutParams(new

   RelativeLayout.LayoutParams(RelativeLayout.LayoutParams.MATCH_PARENT, 
   RelativeLayout.LayoutParams.MATCH_PARENT));
   gameplayRelativeLayoutImages.addView(part1);
 }

1 个答案:

答案 0 :(得分:1)

对您遇到的问题不太确定,但我已经使用这个很酷的课程来创建一段时间的圆形图像,而且我从未遇到过任何问题,请尝试一下。

public class RoundedImageView extends android.support.v7.widget.AppCompatImageView {

public RoundedImageView(Context context) {
    super(context);
}

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

public RoundedImageView(Context context, AttributeSet attrs, int defStyle) {
    super(context, attrs, defStyle);
}

@Override
protected void onDraw(Canvas canvas) {

    Drawable drawable = getDrawable();

    if (drawable == null) {
        return;
    }

    if (getWidth() == 0 || getHeight() == 0) {
        return;
    }
    Bitmap b = ((BitmapDrawable) drawable).getBitmap();
    Bitmap bitmap = b.copy(Bitmap.Config.ARGB_8888, true);

    int w = getWidth(), h = getHeight();

    Bitmap roundBitmap = getCroppedBitmap(bitmap, w);
    canvas.drawBitmap(roundBitmap, 0, 0, null);

}

public static Bitmap getCroppedBitmap(Bitmap bmp, int radius) {
    Bitmap sbmp;

    if (bmp.getWidth() != radius || bmp.getHeight() != radius) {
        float smallest = Math.min(bmp.getWidth(), bmp.getHeight());
        float factor = smallest / radius;
        sbmp = Bitmap.createScaledBitmap(bmp, (int)(bmp.getWidth() / factor),
                (int)(bmp.getHeight() / factor), false);
    } else {
        sbmp = bmp;
    }

    Bitmap output = Bitmap.createBitmap(radius, radius,
            Bitmap.Config.ARGB_8888);
    Canvas canvas = new Canvas(output);

    final int color = 0xffa19774;
    final Paint paint = new Paint();
    final Rect rect = new Rect(0, 0, radius, radius);

    paint.setAntiAlias(true);
    paint.setFilterBitmap(true);
    paint.setDither(true);
    canvas.drawARGB(0, 0, 0, 0);
    paint.setColor(Color.parseColor("#BAB399"));
    canvas.drawCircle(radius / 2 + 0.7f,
            radius / 2 + 0.7f, radius / 2 + 0.1f, paint);
    paint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_IN));
    canvas.drawBitmap(sbmp, rect, rect, paint);

    return output;
}

}

用法:

ImageView mImgView = (ImageView) findViewById(R.id.imageView);
Bitmap bitmap= BitmapFactory.decodeResource(this.getResources(),
            R.drawable.some_image);

// bitmap image, radius
mImgView.setImageBitmap(RoundedImageView.getCroppedBitmap(bitmap, 360));