GridView行高度表现不正常

时间:2012-12-30 14:05:29

标签: android gridview

我正在使用一个GridView,它显示带有背景图像和文本的线性布局,就像这个例子一样:

http://www.curious-creature.org/2012/12/11/android-recipe-1-image-with-rounded-corners/

就像那个例子,我正在使用该代码使图像具有圆角。

问题是,如果我不使用圆角,我的所有网格项都是相同的高度,无论它们里面有什么文字,即使我的所有图像大小相同。

但是如果我使用它,则将项目高度包装到内容中。

我尝试将我的线性布局定义为wrap_content,fill_parent,match_parent甚至是固定高度,但系统只是忽略了我。

这是我的网格布局:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/LinearLayout1"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="#FFDDDDDD"
    android:orientation="vertical"
    tools:context=".RouteListActivity" >

    <GridView
        xmlns:android="http://schemas.android.com/apk/res/android"
        android:id="@+id/gridview"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:layout_margin="20dp"
        android:layout_weight="2"
        android:animateLayoutChanges="false"
        android:clipChildren="false"
        android:clipToPadding="false"
        android:drawSelectorOnTop="true"
        android:gravity="center"
        android:horizontalSpacing="10dp"
        android:numColumns="2"
        android:scrollingCache="false"
        android:stretchMode="columnWidth"
        android:verticalSpacing="10dp" />

</LinearLayout>

这是我的网格项目:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/linearlayoutGridLabel"
    android:layout_width="wrap_content"
    android:layout_height="150dp"
    android:layout_weight="1"
    android:gravity="bottom|left"
    android:orientation="vertical" >

    <TextView
        android:id="@+id/id_ruta"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="TextView"
        android:visibility="gone" />

    <TextView
        android:id="@+id/routenameGridLabel"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_margin="20dp"
        android:background="#77000000"
        android:gravity="bottom"
        android:padding="5dp"
        android:text="Large Text"
        android:textAppearance="?android:attr/textAppearanceLarge" />

</LinearLayout>

在适配器中加上我的getView:

@Override
    public View getView(int position, View convertView, ViewGroup parent) {

        View vi=convertView;
        if(convertView==null)
            vi = inflater.inflate(R.layout.grid_item, null);

        LinearLayout linLayout = (LinearLayout) vi.findViewById(R.id.linearlayoutGridLabel);
        Typeface yanone = Typeface.createFromAsset(mContext.getAssets(), "YanoneKaffeesatz-Regular.ttf");
        TextView id_ruta = (TextView) vi.findViewById(R.id.id_ruta);
        TextView nombre=(TextView)vi.findViewById(R.id.routenameGridLabel);
        nombre.setTypeface(yanone);
        nombre.setTextSize(TypedValue.COMPLEX_UNIT_DIP, 38);
        Ruta current = routeList.get(position);
        try {
//          Drawable d;
//          d = Drawable.createFromStream(mContext.getAssets().open("ruta" + (position+1) + "/title.jpg"), null);
            Bitmap b = BitmapFactory.decodeStream(mContext.getAssets().open("ruta" + (position+1) + "/title.jpg"));
            StreamDrawable d = new StreamDrawable(b, 10, 0);
            linLayout.setBackgroundDrawable(d);
        } catch (IOException e) {
            linLayout.setBackgroundResource(R.drawable.noimage);
        }
        nombre.setText("" + current.getNombre());
        id_ruta.setText(current.getId().toString());

        return vi;
    }

坦率地说,我不了解gridviews的行为。以前我将不同尺寸的图像设置为背景图像,并且所有元素彼此重叠。即使在网格项布局上固定高度,我也无法制作相同大小的行。

我可以在这里找到一些指示吗?

2 个答案:

答案 0 :(得分:32)

我终于解决了它,结果问题在于我正在使用

vi = inflater.inflate(R.layout.grid_item, null);

而不是

vi = inflater.inflate(R.layout.grid_item, parent, false);

因此忽略了布局参数。

无论如何,让GridView均匀分配空间是一件痛苦的事。我想我将切换到TableView。

答案 1 :(得分:1)

您可以使用 setLayoutParams 来设置布局高度:

vi.setLayoutParams(new GridView.LayoutParams(<width_in_pixels>, <height_in_pixels>));

您需要以像素为单位传递宽度和高度。因此,您可能希望将 150dp 转换为像素。