ListView具有addFooterView方法,该方法对于显示加载消息很有用。但是GridView没有这种方法。那么,如何向Google Play中显示的GridView添加页脚视图?
答案 0 :(得分:6)
Android BucketListAdapter
这是一个桶列表适配器的实现,类似于什么 你在Google Play应用中看到了。它具有网格状布局 列表元素的优点,您仍然可以使用列表 页眉和页脚 - 这是标准无法实现的 GridView的。
答案 1 :(得分:0)
不,抱歉,GridView不提供这种功能。
如果您想要“点击此处获取更多信息”条目,我只会在达到当前网格数据的末尾时延迟加载数据。您可以查看CommonsWare的EndlessAdapter,并尝试将其调整为GridView。
答案 2 :(得分:0)
您可以尝试使用相对布局,放置网格视图并使用属性android:layout_alignParentBottom="true"
进行线性布局,它会将您想要的内容放在网格视图下面,这就是我认为你的意思想。
答案 3 :(得分:0)
您可以使用无限滚动侦听器作为gridview的滚动侦听器。通过使用滚动侦听器,您可以获得当前位置。到达终点时显示自定义加载视图,当网络加载完成时(AsyncTask或Loader完成),您可以隐藏加载视图。
答案 4 :(得分:0)
您可以使用此功能,使用OnScrollListener监控滚动位置,滚动到最后一项时,您可以控制加载视图的可见性。
@Override
public void onScroll(AbsListView view, int firstVisibleItem,
int visibleItemCount, int totalItemCount) {
if (mOnScrollListener != null) {
mOnScrollListener.onScroll(view, firstVisibleItem,
visibleItemCount, totalItemCount);
}
// The count of footer view will be add to visibleItemCount also are
// added to totalItemCount
if (visibleItemCount == totalItemCount) {
// If all the item can not fill screen, we should make the
// footer view invisible.
} else if (!mIsLoading
&& (firstVisibleItem + visibleItemCount >= totalItemCount)
&& mCurrentScrollState != SCROLL_STATE_IDLE) {
mIsLoading = true;
if (mOnLoadMoreListener != null) {
mOnLoadMoreListener.onLoadMore();
}
}
}
<LinearLayout
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" >
<LinearLayout
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_weight="1"
android:fillViewport="true" >
<com.baidu.hao123.module.video.view.LoadMoreGridView
android:id="@+id/gv_movie_home"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:cacheColorHint="@null"
android:fitsSystemWindows="true"
android:horizontalSpacing="10dip"
android:listSelector="@android:color/transparent"
android:numColumns="3"
android:paddingLeft="13dip"
android:paddingRight="13dip"
android:paddingTop="10dip"
android:scrollbars="none"
android:verticalSpacing="12dip" />
</LinearLayout>
<LinearLayout
android:id="@+id/auto_load_view"
android:layout_width="wrap_content"
android:layout_gravity="center_horizontal"
android:layout_height="wrap_content"
android:paddingTop="10dip"
android:visibility="gone"
android:paddingBottom="10dip"
android:gravity="center"
android:orientation="horizontal" >
<ProgressBar
android:id="@+id/loadingBar"
android:layout_width="23dip"
android:layout_height="23dip"
android:layout_marginRight="10dip"
android:indeterminateDrawable="@drawable/progress_small" />
<TextView
android:id="@+id/loadingText"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:gravity="center_vertical"
android:text="@string/loading"
android:textColor="@color/color_ff555555"
android:textSize="@dimen/fontSize_middle" />
</LinearLayout>
</LinearLayout>