带有圆角的Android ImageView无法正常工作

Thi*_*ago 8 android

我已经定义了文件thumb_rounded.xml并将其放在我的android应用程序中的res/drawable文件夹中.有了这个文件,我想在我的ImageView中得到包含新闻拇指的圆角,

<shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectangle" >
<corners android:radius="13.0dip" />
</shape>
Run Code Online (Sandbox Code Playgroud)

我将其设置为我的ImageView的背景,但是,我没有得到圆角,图像仍然是一个矩形.有没有人知道怎么做到这一点?我想达到与此屏幕相同的效果:

B&H第一屏

非常感谢

Ť

Chi*_*rag 21

用它,

@Override
public void onCreate(Bundle mBundle) {
super.onCreate(mBundle);
setContentView(R.layout.main);

ImageView image = (ImageView) findViewById(R.id.img);
Bitmap bitImg = BitmapFactory.decodeResource(getResources(),
    R.drawable.default_profile_image);
image.setImageBitmap(getRoundedCornerImage(bitImg));
}

public static Bitmap getRoundedCornerImage(Bitmap bitmap) {
Bitmap output = Bitmap.createBitmap(bitmap.getWidth(),
    bitmap.getHeight(), 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 = 100;

paint.setAntiAlias(true);
canvas.drawARGB(0, 0, 0, 0);
paint.setColor(color);
canvas.drawRoundRect(rectF, roundPx, roundPx, paint);

paint.setXfermode(new PorterDuffXfermode(Mode.SRC_IN));
canvas.drawBitmap(bitmap, rect, rect, paint);

return output;

}
Run Code Online (Sandbox Code Playgroud)

这里,圆形corder依赖于roundPx.


P.M*_*lch 14

如果将视图放在作为蒙版的ImageView顶部,则可以实现精确的圆角图像效果.

看看这个例子:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:background="#ffff"
    android:layout_height="match_parent" >

 <ImageView
    android:id="@+id/image1"
    android:layout_width="200dp"
    android:layout_height="200dp"
    android:padding="10dp"
    android:src="@android:color/holo_red_dark"
    />

<View
    android:layout_width="200dp"
    android:layout_height="200dp"
    android:layout_alignLeft="@+id/image1"
    android:layout_alignTop="@+id/image1"
    android:layout_margin="00dp"
    android:background="@drawable/mask" />
</RelativeLayout>
Run Code Online (Sandbox Code Playgroud)

和一个mask.xml drawable:

<?xml version="1.0" encoding="utf-8"?>
<shape
  xmlns:android="http://schemas.android.com/apk/res/android">
    <corners android:radius="50dp" />    
    <solid android:color="#0000"/>
    <stroke android:color="#ffff" android:width="10dp"/>   
</shape>
Run Code Online (Sandbox Code Playgroud)

两件重要的事情:

  1. 掩码drawable的笔触宽度应与ImageView的填充匹配
  2. 蒙版drawable的笔触颜色应与背景颜色匹配.
  3. 必须调整遮罩角的半径以与笔划宽度相对应(因此您不会看到遮罩后面的图像).

该示例生成以下图像: 在此输入图像描述

HTH


Ped*_*iro 3

您缺少几个标签。这是一个新示例:

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectangle"> 
    <solid android:color="#ffffff"/>    

    <stroke android:width="3dp"
            android:color="#ff000000"/>

    <padding android:left="1dp"
             android:top="1dp"
             android:right="1dp"
             android:bottom="1dp"/> 

    <corners android:radius="30px"/> 
</shape>
Run Code Online (Sandbox Code Playgroud)

在这里看到的

另外,您知道RoundRectShape吗?

  • 这似乎不起作用。 (6认同)
  • 它似乎不起作用 (3认同)
  • 为什么要接受答案?不起作用! (3认同)
  • 你的代码不起作用。它应该是一个白色背景的圆角矩形,比我的图像大......我会看看 RoundRectShape,谢谢@Pedro (2认同)