android网格视图显示每个网格下方的标题

时间:2011-12-04 03:30:36

标签: android grid

我想在每个网格图像下面显示一些文字。

请参阅下面的代码。 请帮我找出它不起作用的原因 我正在显示图像,但没有文字 如果我试图在图像中显示文字即将到来 所以它应该是定义布局的东西。但我无法调试

适配器代码:

 public View getView(final int position, View convertView, ViewGroup parent) {
    ViewHolder holder;

    if (convertView == null) {
        LayoutInflater mInflater = (LayoutInflater) mContext
                .getSystemService(Context.LAYOUT_INFLATER_SERVICE);
        convertView = mInflater.inflate(R.layout.griditems, null);
        holder = new ViewHolder();
    holder.text1 = (TextView) convertView
                .findViewById(R.id.grid_item_text);
    Log.i(TAG, holder.text1.toString());
        holder.image = (ImageView) convertView
                .findViewById(R.id.grid_item_image);


            // if it's not recycled, initialize some attributes
            holder.image.setImageResource(gridItemIds[position]);
            holder.text1.setText(gridTitles[position]);
        //holder.image.setScaleType(ImageView.ScaleType.FIT_XY);
        // holder.image.setPadding(20, 20, 20, 20);

    convertView.setLayoutParams(new GridView.LayoutParams(Utils
                .getLayoutParameter(), Utils.getLayoutParameter()));

        holder.image.setOnClickListener(new View.OnClickListener() {

            @Override
            public void onClick(View view) {

            }
        });
        convertView.setTag(holder);
    } else {

        holder = (ViewHolder) convertView.getTag();

    }

    return convertView;
}

static class ViewHolder {
    TextView text1;
    ImageView image;

}



    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
   android:id="@+id/GridItem"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:orientation="vertical"
   android:gravity="center_horizontal"
  >

   <ImageView android:id="@+id/grid_item_image"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content">
   </ImageView>

   <TextView android:id="@+id/grid_item_text"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:text="TextView"
      android:textColor="#000000"
      >
   </TextView>

</LinearLayout>

gridview:

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


        <TextView android:id="@+id/text1view" android:textStyle="bold"
            android:layout_width="fill_parent" android:layout_height="wrap_content"
            android:gravity="center_horizontal" android:background="@drawable/title_bar" 
            />

        <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:verticalSpacing="50dip"
            android:horizontalSpacing="10dp" android:numColumns="3"
            android:stretchMode="columnWidth"
            android:layout_below="@+id/text1view" 
                         android:gravity="center"
            android:layout_centerHorizontal="true" 
            android:background="@drawable/home_bg"
                        />


</LinearLayout>

2 个答案:

答案 0 :(得分:0)

我使用了你的xml,但是我写了一个简单的数组适配器,一切都很完美,试着用我的替换你的适配器,让我知道,谢谢。

class ItemsAdapter extends ArrayAdapter<String> {

    public ItemsAdapter(Context context, List<String> list) {
        super(context, R.layout.griditems, list);
    }

    @Override
    public View getView(final int position, View row, final ViewGroup parent) {
        final String item = getItem(position);

        ItemWrapper wrapper = null;
        if (row == null) {
            row = getLayoutInflater().inflate(R.layout.griditems, parent, false);
            wrapper = new ItemWrapper(row);

            row.setTag(wrapper);
        } else {
            wrapper = (ItemWrapper) row.getTag();
        }
        wrapper.refreshData(item);

        return row;
    }

}    

static class ItemWrapper {

    TextView text;
    ImageView img;

    public ItemWrapper(View row) {
        text = (TextView) row.findViewById(R.id.grid_item_text);
        img = (ImageView) row.findViewById(R.id.grid_item_image);
    }

    public void refreshData(String item) {
        img.setImageResource(R.drawable.image_1);
        text.setText(item);
    }

}

答案 1 :(得分:0)

也尝试使用RelativeLayout,使用

将TextView放在ImageView下面
 android:layout_below="@id/grid_item_image"

它会将其放置在图像下方,但是,如果您可以选择使用图形布局,则将其与图像一起拖动到所需的位置将为您设置所有参数,而不是将其输入。 / p>