到目前为止,我能够做到这一点的方法是创建一个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的属性!
答案 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>