GridView中的项目不可见。

3

我正在使用一个GridView来展示一些图片。我已经编写了相关代码,但是仍未能获取到任何图片。

自定义适配器

public class CustomAdapter extends BaseAdapter {

    private Context context;
    private int[] images;

    public CustomAdapter(Context context, int[] images) {
        this.context = context;
        this.images = images;
    }

    @Override
    public int getCount() {
        return images.length;
    }

    @Override
    public Object getItem(int position) {
        return images[position];
    }

    @Override
    public long getItemId(int position) {
        return position;
    }

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        ViewHolder holder;
        if (convertView == null) {
            holder = new ViewHolder();
            convertView = LayoutInflater.from(context).inflate(R.layout.custom_trips_frag_row, parent, false);
//            holder.tvHeader = (TextView) convertView.findViewById(R.id.tv_trips_home_header);
//            holder.tvDate = (TextView) convertView.findViewById(R.id.tv_trips_home_date);
            holder.ivImage = (ImageView) convertView.findViewById(R.id.iv_trips_home_image);
            convertView.setTag(holder);

        } else {
            holder = (ViewHolder) convertView.getTag();
        }

//        

        holder.ivImage.setImageResource(images[position]);


        return convertView;
    }


    private class ViewHolder {
        private TextView tvHeader;
        private TextView tvDate;
        private ImageView ivImage;
    }
} 

主要活动
public class MainActivity extends MasterActivity {
    private int[] images={R.drawable.images, R.drawable.images_2, R.drawable.images_1, R.drawable.images_4, R.drawable.images, R.drawable.images_2};
    private GridView gridView;


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.trips_frag);

        gridView = (GridView) findViewById(R.id.grid);
        gridView.setAdapter(new CustomAdapter(this, images));


    }
}

自定义行 XML

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


    <ImageView
        android:layout_width="200dp"
        android:layout_height="200dp"
        android:id="@+id/iv_trips_home_image"
        android:src="@drawable/images"
        android:layout_alignParentTop="true"
        android:layout_centerHorizontal="true" />

    <!--<TextView-->
        <!--android:layout_width="wrap_content"-->
        <!--android:layout_height="wrap_content"-->
        <!--android:layout_below="@+id/iv_trips_home_image"-->
        <!--android:layout_centerHorizontal="true"-->
        <!--android:id="@+id/tv_trips_home_header" />-->

    <!--<triplogger.indiehustlers.com.triplogger.UTIL.CustomTextView-->
        <!--android:layout_width="wrap_content"-->
        <!--android:layout_height="wrap_content"-->
        <!--android:id="@+id/tv_trips_home_header"-->
        <!--style="@style/textView"-->
        <!--android:text="Berlin"-->
        <!--android:textColor="#000"-->
        <!--android:textStyle="bold"-->
        <!--android:textSize="@dimen/header_text"-->
        <!--android:layout_below="@+id/iv_trips_home_image"-->
        <!--android:layout_centerHorizontal="true" />-->


    <!--<triplogger.indiehustlers.com.triplogger.UTIL.CustomTextView-->
        <!--android:layout_width="wrap_content"-->
        <!--android:layout_height="wrap_content"-->
        <!--android:text="14-Sept-2014"-->
        <!--style="@style/textView"-->
        <!--android:visibility="gone"-->
        <!--android:textColor="#23170e17"-->
        <!--android:id="@+id/tv_trips_home_date"-->
        <!--android:layout_below="@+id/tv_trips_home_header"-->
        <!--android:layout_centerHorizontal="true" />-->
</RelativeLayout>

主活动

public class MasterActivity extends Activity {
    protected Context activityContext;


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        activityContext = getApplicationContext();
    }
}

trips_frag

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_marginRight="@dimen/margin_right"
    android:layout_marginLeft="@dimen/margin_left"

    android:layout_height="match_parent">


    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"

        android:orientation="horizontal">

        <ImageView
            android:layout_width="0dp"
            android:layout_height="match_parent"
            android:layout_weight="1"
            android:src="@drawable/tab" />


        <ImageView
            android:layout_width="0dp"
            android:layout_height="match_parent"
            android:layout_weight="1"
            android:src="@drawable/tab" />

    </LinearLayout>

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
       >

        <GridView
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:numColumns="2"
            android:id="@+id/grid"
            android:verticalSpacing="5dp"
            android:stretchMode="spacingWidthUniform"></GridView>

    </LinearLayout>

</LinearLayout>

清单

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="triplogger.indiehustlers.com.triplogger">



    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/TripLoggerTheme">
        <activity
            android:name=".MainActivity"
            android:label="@string/app_name">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest>

我做了很多研究,但仍然没有成功。我不知道哪里出了问题?请帮帮我。


1
你的 MasterActivity 类包含了什么? - Piyush
只需展示那个类即可。 - Piyush
当我运行应用程序时,没有任何内容显示。 - Anuj
1
请问您能否发布包含GridView的AndroidManifest和XML文件? - user1140237
@user1140237 已添加,先生。 - Anuj
显示剩余7条评论
3个回答

10
从GridView中移除android:stretchMode="spacingWidthUniform"。 您已经在项布局中修复了图像视图网格项的高度和宽度。
 <?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:orientation="vertical" >

    <GridView
        android:id="@+id/griddata"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:numColumns="2"
        android:stretchMode="spacingWidthUniform"
        android:verticalSpacing="5dp" >
    </GridView>

</LinearLayout>

网格项布局

    <?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="match_parent"
    android:orientation="vertical" >

    <ImageView
        android:id="@+id/iv_trips_home_image"
        android:layout_width="200dp"
        android:layout_height="200dp"
        android:layout_alignParentTop="true"
        android:layout_centerHorizontal="true" />

    <!-- <TextView -->
    <!-- android:layout_width="wrap_content" -->
    <!-- android:layout_height="wrap_content" -->
    <!-- android:layout_below="@+id/iv_trips_home_image" -->
    <!-- android:layout_centerHorizontal="true" -->
    <!-- android:id="@+id/tv_trips_home_header" /> -->


    <!-- <triplogger.indiehustlers.com.triplogger.UTIL.CustomTextView -->
    <!-- android:layout_width="wrap_content" -->
    <!-- android:layout_height="wrap_content" -->
    <!-- android:id="@+id/tv_trips_home_header" -->
    <!-- style="@style/textView" -->
    <!-- android:text="Berlin" -->
    <!-- android:textColor="#000" -->
    <!-- android:textStyle="bold" -->
    <!-- android:textSize="@dimen/header_text" -->
    <!-- android:layout_below="@+id/iv_trips_home_image" -->
    <!-- android:layout_centerHorizontal="true" /> -->


    <!-- <triplogger.indiehustlers.com.triplogger.UTIL.CustomTextView -->
    <!-- android:layout_width="wrap_content" -->
    <!-- android:layout_height="wrap_content" -->
    <!-- android:text="14-Sept-2014" -->
    <!-- style="@style/textView" -->
    <!-- android:visibility="gone" -->
    <!-- android:textColor="#23170e17" -->
    <!-- android:id="@+id/tv_trips_home_date" -->
    <!-- android:layout_below="@+id/tv_trips_home_header" -->
    <!-- android:layout_centerHorizontal="true" /> -->

</RelativeLayout>

谢谢您,但是如何在两张图片之间添加空格? - Anuj
1
你可以使用 android:horizontalSpacing 或 android:verticalSpacing 来设置间距。如果找到解决方案,请放弃。 - user1140237
@user1140237,我以前从未意识到当您为GridView项设置固定大小时,“android:stretchMode”会产生如此巨大的影响。 - Edijae Crusar

1

从GridView中删除strechMode,并在custom_trips_frag_row.xml的ImageView中添加android:gravity="center"。

<GridView
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:numColumns="2"
    android:id="@+id/grid"
    android:verticalSpacing="5dp">
</GridView>

1
花了约4个小时,我发现我的代码有一个错误。我复制了GridView适配器的this code,但是发现GridView内部没有显示图片(或文本标签)。我尝试了很多来自Gridview height gets cutHow to have a GridView that adapts its height when items are added的答案,并且了解到我的内部视图(ImageView)无法测量它们的宽度和高度
当然,我可以设置gridView.layoutParams.height = 300,并且ImageView将会显示,但这取决于ImageView的大小。所以,我发现了ImageView创建中的错误。
我必须写成:view = LayoutInflater.from((context)).inflate(R.layout.image_layout, parent, false)
view = LayoutInflater.from((context)).inflate(R.layout.image_layout, parent, false)

在这种情况下,新视图将附加到GridView并且可以测量它们的大小。
因此,这是getView方法的示例:
override fun getView(position: Int, convertView: View?, parent: ViewGroup?): View {
    val holder: ViewHolder
    val view: View
    if (convertView == null) {
        holder = ViewHolder()
        view = LayoutInflater.from((context)).inflate(layoutRes, parent, false)
        view.tag = holder
        holder.imageView = view as ImageView
    } else {
        holder = convertView.tag as ViewHolder
        view = convertView
    }
    // Show an image with Glide, for instance.
    with(getItem(position)) {
        showPhoto(holder.imageView, this)
    }
    return view
}

从旧手册中复制粘贴是一种耻辱。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接