从ImageView和TextView创建图像

时间:2015-10-08 09:42:22

标签: android image gridview layout bitmap

我有一个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的每个元素都是这样的图像:

item 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中设置元素的圆角图像。我该怎么做才能达到这个效果?

提前致谢。

1 个答案:

答案 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。