posts - 71,  comments - 203,  views - 79万
其实原理很简单,只需要设置监听listview的滚动事件即可,
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
package cn.stay.activity;
import java.util.ArrayList;
import java.util.List;
import com.aoran.R;
import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.widget.AbsListView;
import android.widget.AbsListView.OnScrollListener;
import android.widget.LinearLayout;
import android.widget.ListView;
import android.widget.ProgressBar;
 
/**
 * @author riddlezhang
 *  滚动listview提示等待框
 */
public class ListView_sep extends Activity implements OnScrollListener {
 
    private List<String> list = new ArrayList<String>();
    private ListView listv01;
    private MyAdapter adapter;
    private int current_page = 2;
    ProgressBar progressBar;
    private LinearLayout bottom_linear;
    private int lastItem;
     
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        // TODO Auto-generated method stub
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
 
        listv01 = (ListView) findViewById(R.id.listv01);
        bottom_linear=(LinearLayout) findViewById(R.id.bottom_linear);
        for (int i = 0; i < 100; i++) {
            list.add("i="+i);
        }
        adapter = new MyAdapter(ListView_sep.this, list);
        listv01.setAdapter(adapter);
//      listv01.setSelection(getSingerStrs().size()-1); 设置每次最后一行被选中
        listv01.setOnScrollListener(this);
    }
    @Override
    public void onScrollStateChanged(AbsListView view, int scrollState) {
        if (lastItem==adapter.count && scrollState == OnScrollListener.SCROLL_STATE_IDLE) {
            if ((list.size() - current_page * 10) > 0) {
                bottom_linear.setVisibility(View.VISIBLE);
                if ((list.size() - current_page * 10) >= 10) {
                    adapter.count += 10;
                } else {
                    adapter.count += (list.size() - current_page * 10);
                }
                current_page++;
                adapter.notifyDataSetChanged();
//              bottom_linear.setVisibility(View.GONE);
            }
        }
    }
    @Override
    public void onScroll(AbsListView view, int firstVisibleItem,
            int visibleItemCount, int totalItemCount) {
            lastItem=firstVisibleItem+visibleItemCount;
    }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
package cn.stay.activity;
 
import java.util.List;
 
import com.aoran.R;
 
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.TextView;
 
public class MyAdapter extends BaseAdapter{
    private Context mContext;
    private List<String> list;
    public int count=20;
    private ViewHolder holder;
     
    public MyAdapter(Context mContext,List<String> list) {
        this.mContext=mContext;
        this.list=list;
    }
    @Override
    public int getCount() {
        return count;
    }
 
    @Override
    public Object getItem(int position) {
        // TODO Auto-generated method stub
        return list.get(position);
    }
 
    @Override
    public long getItemId(int position) {
        return position;
    }
 
    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        // TODO Auto-generated method stub
        if(convertView==null || convertView.getTag()==null){
            convertView=LayoutInflater.from(mContext).inflate(R.layout.adapter,null);
            holder = new ViewHolder();
            holder.adapter_tv=(TextView) convertView.findViewById(R.id.adapter_tv);
            convertView.setTag(holder);
            }else{
                holder=(ViewHolder) convertView.getTag();
            }
        holder.adapter_tv.setText(list.get(position));
        return convertView;
    }
 
    private class ViewHolder{
        private TextView adapter_tv;
    }
}

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
main.xml
 
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:background="@drawable/project_main_bg"
    >
    <LinearLayout android:id="@+id/bottom_linear" android:layout_alignParentBottom="true" android:layout_width="fill_parent" android:layout_height="50dip" android:gravity="center" android:visibility="gone">
        <ProgressBar android:layout_width="24dip" android:layout_height="24dip" android:layout_marginLeft="20dip" />
        <TextView android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="正在加载,请稍后。。。" android:textColor="#FFFFFF" android:textSize="20sp" android:gravity="center"/>
    </LinearLayout>
    <ListView android:id="@+id/listv01" android:background="@null" android:layout_above="@id/bottom_linear" android:layout_width="fill_parent" android:layout_height="wrap_content" android:listSelector="#00000000" android:cacheColorHint="#00000000"/>
</RelativeLayout>
posted on   stay  阅读(7579)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
点击右上角即可分享
微信分享提示