Android 取整ImageView角点的方法会产生不同的结果
我有一个ImageView,其中我想使ImageView的角变圆。我发现以下方法可以达到这种效果:Android 取整ImageView角点的方法会产生不同的结果,android,bitmap,Android,Bitmap,我有一个ImageView,其中我想使ImageView的角变圆。我发现以下方法可以达到这种效果: public static Bitmap getRoundedCornerBitmap(Bitmap bitmap, int pixels) { Bitmap output = Bitmap.createBitmap(bitmap.getWidth(), bitmap.getHeight(), Bitmap.Config.ARGB_8888); Canvas canvas = ne
public static Bitmap getRoundedCornerBitmap(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 Paint paint = new Paint();
final Rect rect = new Rect(0, 0, bitmap.getWidth(), bitmap.getHeight());
final RectF rectF = new RectF(rect);
final float roundPx = pixels;
paint.setAntiAlias(true);
canvas.drawARGB(0, 0, 0, 0);
paint.setColor(color);
canvas.drawRoundRect(rectF, roundPx, roundPx, paint);
paint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_IN));
canvas.drawBitmap(bitmap, rect, rect, paint);
return output;
}
这个方法很好用,我传入一个位图,指定半径,输出的位图有适当剪裁和圆角的角
对于用法,我有一个活动,用户可以在其中拍照或从图库中选择一张照片,或者如果他两者都不拍照,则选择默认照片。因此,我有以下代码:
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
switch (requestCode) {
case Constants.TAKE_PHOTO:
if (resultCode == RESULT_OK) {
mPhoto = (Bitmap) data.getExtras().get("data");
Bitmap croppedImage = bitmapMethods.cropImage(mPhoto);
finalPhoto = bitmapMethods.getRoundedCornerBitmap(croppedImage, 30);
imageView.setImageBitmap(finalPhoto);
}
break;
case Constants.CHOOSE_PHOTO:
if (resultCode == RESULT_OK) {
Uri selectedImage = data.getData();
mPhoto = bitmapMethods.decodeFile(selectedImage, mContext);
Bitmap croppedImage = bitmapMethods.cropImage(mPhoto);
finalPhoto = bitmapMethods.getRoundedCornerBitmap(croppedImage, 30);
imageView.setImageBitmap(finalPhoto);
}
break;
}
}
这里的bitmapMethods.cropImage()
是一种保证图像长度和宽度相同的方法。现在奇怪的是,如果我用相机拍一张照片,几乎可以看到一个圆形的图像。如果通过相同的方法传递默认照片或所选照片,则图像会显示出所需的略微圆角
我的问题是为什么会这样?我将相同的int像素
传递到每个方法中(在其30个以上的方法中),那么为什么拍摄的照片显示为圆形,而选择的照片显示为具有圆形边缘的矩形?该“数据”给出了捕获图像的缩略图。与画廊中存储的5MP图像相比,这将是非常小的。因此,200px 200px缩略图上的30px圆角将使其看起来像一个圆形,而在1024px 768px图像上,则使其感觉像一个圆角矩形
你可以尝试存储更大的图像并阅读它们