我有一个GridView片段,GridView的每个元素都有ImageView和TextView。我想用ImageView和TextView创建和成像,是否可能?
这是GridView元素的代码:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:paddingBottom="15dp"
android:orientation="vertical"
android:descendantFocusability="blocksDescendants" >
<ImageView
android:id="@+id/imgGrid"
android:layout_width="80dp"
android:layout_height="80dp"
android:layout_alignParentTop="true"
android:layout_alignWithParentIfMissing="false"
android:layout_centerHorizontal="true"
android:layout_centerVertical="false"
android:layout_marginTop="5dp"
android:scaleType="centerInside"
android:src="@drawable/myImg" />
<TextView
android:id="@+id/nameGrid"
android:layout_width="100dp"
android:layout_height="wrap_content"
android:layout_below="@+id/imgGrid"
android:layout_centerHorizontal="true"
android:background="@drawable/border_blue"
android:gravity="center"
android:text="My image"
android:textColor="#ffffff"
android:textStyle="bold" />
</RelativeLayout>
我希望GridView的每个元素都是这样的图像:
我使用以下代码执行圆角图像:
public static Bitmap getRoundedCornerBitmap(Bitmap bitmap, Context mContext) {
int w = bitmap.getWidth();
int h = bitmap.getHeight();
int radius = Math.min(h / 2, w / 2);
Bitmap output = Bitmap.createBitmap(w + 8, h + 8, Bitmap.Config.ARGB_8888);
Paint p = new Paint();
p.setAntiAlias(true);
Canvas c = new Canvas(output);
c.drawARGB(0, 0, 0, 0);
p.setStyle(Paint.Style.FILL);
c.drawCircle((w / 2) + 4, (h / 2) + 4, radius, p);
p.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_IN));
c.drawBitmap(bitmap, 4, 4, p);
p.setXfermode(null);
p.setStyle(Paint.Style.STROKE);
p.setColor(mContext.getResources().getColor(R.color.myPrimaryColor));
p.setStrokeWidth(4);
c.drawCircle((w / 2) + 4, (h / 2) + 4, radius, p);
return output;
}
然后我需要在一个图像中链接ImageView和TextView,以在GridView中设置元素的圆角图像。我该怎么做才能达到这个效果?
提前致谢。
答案 0 :(得分:2)
尝试在像这样的相对布局中添加imageview和textview
<ImageView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:src="@drawable/powered_by_google_light"/>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="your text here"
android:layout_alignParentBottom="true"
android:layout_centerHorizontal="true"/>
</RelativeLayout>
这里整个相对布局充当了一个带有textview的imageview。