效果图:
listview和gridview都是可滑动的控件(Scrollbar)
在Android中,不能在一个拥有Scrollbar的组件中嵌入另一个拥有Scrollbar的组件
因为这会混淆滑动事件,导致高度只显示其中的一行的高度且滑动事件不能触发。
所以,我们重写一个gridView组件继承自GridView,在onMeasure方法中禁用滚动事件,将所有的item显示出来
import android.content.Context;
import android.util.AttributeSet;
import android.widget.GridView;
public class NoScrollGridView extends GridView {
public NoScrollGridView(Context context) {
super(context);
}
public NoScrollGridView(Context context, AttributeSet attrs) {
super(context, attrs);
}
@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
int expandSpec = MeasureSpec.makeMeasureSpec(Integer.MAX_VALUE >> 2, MeasureSpec.AT_MOST);
super.onMeasure(widthMeasureSpec, expandSpec);
}
}
到这里我们已经解决了gridview的高度问题
布局:1.最外层ListView
<ListView android:layout_width="match_parent"
android:layout_height="wrap_content"
android:id="@+id/in_album_list_items"/>
**2.listItem中的GridView布局(解决问题高度的重点就在这里!)**
<TextView
android:id="@+id/up_time_day"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginLeft="15dp"
android:layout_marginTop="5dp"
android:text="2016/06/07"
android:textSize="16dp" />
<com.example.gridviewinlistview.NoScrollGridView
android:id="@+id/in_album_list_item_img"
android:layout_width="match_parent"
android:layout_margin="15dp"
android:layout_height="wrap_content"
android:numColumns="3"
android:verticalSpacing="10dp"
android:horizontalSpacing="10dp"
/>
**3GridviewItem,我的只是有一张照片** <?xml version="1.0" encoding="utf-8"?>
需要注意的是这种类型的数据格式是
[{“time”:“20191012”,“photoList”:[{“id”:7,“albumId”:1,“userId”:1,“pdescribe”:null,“ptime”:“20191012”,“place”:“beij”,“path”:"",“identify”:null},{“id”:8,“albumId”:1,“userId”:1,“pdescribe”:null,“ptime”:“20191012”,“place”:“北京”,“path”:"",“identify”:null}]}
所以涉及的两个类就是,photo类和phtolist.
photo类:
public class Photo {
private int id;
private int albumId;
private int userId;
private String pdescribe;
private String ptime;
private String place;
private String path;
private String identify;
//以及getset方法toString方法,或者构造方法等
}
phtolist类
public class PhotoList {
private String ptime;
private List<Photo> photoLists;
//getset 、toString方法
}
前期的准备工作已经结束,下面是千篇一律的创建adapter,添加数据。
首先介绍的是最内层的gridview的adapter,传入的数据是一个List
请看代码
/**
* @ClassName
* @Description 第二层GridViewAdapter
* @Author zn
* @Date 2020-05-03
*/
public class GridViewImgAdapter extends BaseAdapter {
private Context context; // 上下文环境
private List