自定义 GridView 项

Custom GridView Item

如何创建如下所示的自定义 GridView 项目?

布局是我写的 -

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:orientation="vertical"
    android:background="@drawable/round_corner_drawable">

<ImageView
    android:id="@+id/market_image"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_marginLeft="5dp"
    android:layout_marginRight="5dp"
    android:src="@drawable/default_image"/>

    <TextView

        android:id="@+id/nameTV"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginLeft="5dp"
        android:text="Text 1"/>

    <TextView
        android:id="@+id/priceTV"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginLeft="5dp"
        android:text="Text 2"/>
</LinearLayout>

为了让它成为正方形,我在适配器 getView() 方法中添加了这些行 -

GridView grid = (GridView)parent;
int size = grid.getColumnWidth();
view.setLayoutParams(new GridView.LayoutParams(size, size));

在设备上 运行 之后,我得到了以下结果。 图像视图下方的文本被裁剪且不可见。我还希望 imageview 位于布局之上,如上图所示。请帮忙

我正在使用的图像 -

尝试为图像布局赋予权重=1:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:orientation="vertical"
    android:background="@drawable/round_corner_drawable">

<ImageView
    android:id="@+id/market_image"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_weight="1"
    android:layout_marginLeft="5dp"
    android:layout_marginRight="5dp"
    android:src="@drawable/default_image"/>

    <TextView

        android:id="@+id/nameTV"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginLeft="5dp"
        android:text="Text 1"/>

    <TextView
        android:id="@+id/priceTV"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginLeft="5dp"
        android:text="Text 2"/>
</LinearLayout>

同上xml.

尝试使用以下布局:

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

<View
    android:id="@+id/anchor"
    android:layout_width="0dp"
    android:layout_height="0dp"
    android:layout_alignParentTop="true" />

<ImageView
    android:id="@+id/market_image"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_above="@+id/nameTV"
    android:layout_below="@+id/anchor"
    android:layout_centerHorizontal="true"
    android:layout_marginLeft="5dp"
    android:layout_marginRight="5dp"
    android:src="@drawable/ic_launcher" />

<TextView
    android:id="@+id/nameTV"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_marginLeft="5dp"
    android:layout_above="@+id/priceTV"
    android:gravity="center_horizontal"
    android:text="Text 1" />

<TextView
    android:id="@+id/priceTV"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_alignParentBottom="true"
    android:layout_marginLeft="5dp"
    android:gravity="center_horizontal"
    android:text="Text 2" />

</RelativeLayout>

或使用以下布局

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:weightSum="100"
android:orientation="vertical">

<ImageView
android:id="@+id/market_image"
android:layout_width="wrap_content"
android:layout_height=match_parent
android:layout_marginLeft="5dp"
android:layout_marginRight="5dp"
android:layout_weight="10"
android:src="@drawable/ic_launcher"/>

<TextView

    android:id="@+id/nameTV"
    android:layout_width="wrap_content"
    android:layout_height="match_parent"
    android:layout_marginLeft="5dp"
     android:layout_weight="45"
    android:text="Text 1"/>

<TextView
    android:id="@+id/priceTV"
    android:layout_width="wrap_content"
    android:layout_height="match_parent"
    android:layout_marginLeft="5dp"
     android:layout_weight="45"
    android:text="Text 2"/>
</LinearLayout>

终于解决了。 我在下面写了布局以获得所需的输出

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/rootView"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >

<RelativeLayout
    android:layout_width="210dp"
    android:layout_height="240dp"
    android:background="@drawable/round_corner_drawable"
    android:layout_marginTop="15dp">

    <TextView

        android:id="@+id/nameTV"
        android:layout_above="@+id/priceTV"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginLeft="5dp"
        android:text="Latin American Republic"/>

    <TextView
        android:id="@+id/priceTV"
        android:layout_alignParentBottom="true"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginLeft="5dp"
        android:text="65$"/>
</RelativeLayout>

<ImageView
    android:id="@+id/market_image"
    android:layout_width="190dp"
    android:layout_height="200dp"
    android:layout_marginLeft="5dp"
    android:layout_marginRight="5dp"
    android:scaleType="fitXY"
    android:src="@drawable/default_marketplace"/>




</RelativeLayout>