Android编程实现ListView滚动提示等待框功能示例
作者:Gobby.X 时间:2022-11-15 13:50:15
本文实例讲述了Android编程实现ListView滚动提示等待框功能。分享给大家供大家参考,具体如下:
其实原理很简单,只需要设置监听listview的滚动事件即可
file1:
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;
}
}
file2:
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;
}
}
file3:
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>
希望本文所述对大家Android程序设计有所帮助。
标签:Android,ListView
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
Android编程实现应用强制安装到手机内存的方法
2023-11-09 14:00:40
Java原生序列化和反序列化代码实例
2023-10-29 21:46:45
Android Walker登录记住密码页面功能实现
2023-12-16 05:45:03
![](https://img.aspxhome.com/file/2023/6/137436_0s.jpg)
详解Flutter和Dart取消Future的三种方法
2022-10-15 12:44:16
![](https://img.aspxhome.com/file/2023/9/138839_0s.jpg)
Java Http的基础概念了解
2021-08-12 04:23:28
![](https://img.aspxhome.com/file/2023/9/122029_0s.png)
C#使⽤XmlReader和XmlWriter操作XML⽂件
2023-12-13 10:25:00
DevExpress获取TreeList可视区域节点集合的实现方法
2023-09-18 15:42:05
详解Java设计模式之备忘录模式的使用
2023-09-10 09:38:32
![](https://img.aspxhome.com/file/2023/7/58437_0s.jpg)
Android TabLayout设置指示器宽度的方法
2023-03-27 02:53:05
![](https://img.aspxhome.com/file/2023/0/109180_0s.png)
java实现手写一个简单版的线程池
2022-09-29 04:59:32
![](https://img.aspxhome.com/file/2023/6/62726_0s.jpg)
Java输入/输出流体系详解
2023-03-01 06:37:00
![](https://img.aspxhome.com/file/2023/9/65739_0s.png)
Java设计模式之命令模式_动力节点Java学院整理
2023-12-11 13:32:03
![](https://img.aspxhome.com/file/2023/3/69913_0s.png)
Spring依赖注入与第三方Bean管理基础详解
2022-09-08 20:45:55
![](https://img.aspxhome.com/file/2023/9/66189_0s.png)
C语言实现俄罗斯方块源代码
2023-02-28 13:16:45
C#实现获取程序路径方法小结
2022-05-09 19:40:48
详解JAVA类加载机制
2023-11-08 04:05:16
![](https://img.aspxhome.com/file/2023/0/74910_0s.png)
maven中下载jar包源码和javadoc的命令介绍
2023-07-27 04:41:01
![](https://img.aspxhome.com/file/2023/3/61033_0s.png)
详解Spring Boot微服务如何集成fescar解决分布式事务问题
2022-01-21 18:43:51
![](https://img.aspxhome.com/file/2023/1/67951_0s.png)
Android Handler之消息循环的深入解析
2022-02-10 20:08:45
![](https://img.aspxhome.com/file/2023/4/101854_0s.png)
Java之InputStreamReader类的实现
2023-09-03 01:28:17