GridView的addFooterView对应物是什么?

时间:2012-07-15 23:18:54

标签: android gridview

ListView具有addFooterView方法,该方法对于显示加载消息很有用。但是GridView没有这种方法。那么,如何向Google Play中显示的GridView添加页脚视图? Google Play loading footer view

5 个答案:

答案 0 :(得分:6)

  

Android BucketListAdapter

     

这是一个桶列表适配器的实现,类似于什么   你在Google Play应用中看到了。它具有网格状布局   列表元素的优点,您仍然可以使用列表   页眉和页脚 - 这是标准无法实现的   GridView的。

链接:https://github.com/rzsombor/bucket-list-adapter

答案 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>