如何以编程方式为我的ImageView添加圆角边框?

时间:2016-09-23 14:49:43

标签: java android xml imageview drawable

到目前为止,我能够做到这一点的方法是创建一个XML drawable:

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectangle">
    <solid android:color="#00ffffff" />
    <padding
        android:left="0dp"
        android:top="0dp"
        android:right="0dp"
        android:bottom="0dp" />
    <corners android:radius="12dp" />
    <stroke android:width="3dp" android:color="#ffffffff" />
</shape>

在我的布局XML中:

        <FrameLayout
            android:layout_width="64dp"
            android:layout_height="64dp"
            android:layout_gravity="top|center_horizontal">

            <ImageView
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:id="@+id/profilePicture"
                android:scaleType="fitXY"
                android:clickable="true"
                android:contentDescription="@string/content_desc_profile_picture" />

            <ImageView
                android:src="@drawable/frame"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:contentDescription="@string/content_desc_default_profile_picture" />

        </FrameLayout>

我的问题是框架没有覆盖在其背后的profilePicture可绘制的角落,使实际图像在边界上渗出。我怎样才能遮住角落?真的希望现在有这样一个类似CSS的属性!

1 个答案:

答案 0 :(得分:1)

shape.xml

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

您的布局.xml

 <FrameLayout
        android:layout_width="64dp"
        android:layout_height="64dp"
        android:layout_gravity="top|center_horizontal" xmlns:android="http://schemas.android.com/apk/res/android">



    <ImageView
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:background="@drawable/shape"
    />
    <ImageView
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:id="@+id/profilePicture"
            android:scaleType="fitXY"
            android:clickable="true"
            android:layout_margin="5dp"
            android:src="@drawable/your_image"
            android:background="@drawable/shape" />

</FrameLayout>