Android编程实现ListView滚动提示等待框功能示例
本文实例讲述了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视图View技巧总结》、《Android布局layout技巧总结》、《Android图形与图像处理技巧总结》、《Android开发入门与进阶教程》、《Android调试技巧与常见问题解决方法汇总》、《Android多媒体操作技巧汇总(音频,视频,录音等)》、《Android基本组件用法总结》及《Android控件用法总结》
希望本文所述对大家Android程序设计有所帮助。
- Android ListView滚动到指定的位置
- Android ListView滚动到底后自动加载数据
- Android基于ListView实现类似QQ空间的滚动翻页与滚动加载效果
- Android简单记录和恢复ListView滚动位置的方法
- Android程序开发之ListView实现横向滚动(带表头与固定列)
- Android开发ListView中下拉刷新上拉加载及带列的横向滚动实现方法
- Android程序开发ListView+Json+异步网络图片加载+滚动翻页的例子(图片能缓存,图片不错乱)
- android ListView的右边滚动滑块启用方法 分享
- android listview 水平滚动和垂直滚动的小例子
- android ListView自动滚动方法
- android开发之横向滚动/竖向滚动的ListView(固定列头)
相关文章
android使用FlipAnimation实现3D垂直翻转动画
这篇文章主要为大家详细介绍了android使用FlipAnimation实现3D垂直翻转动画,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2017-12-12Android 使用viewpager实现无限循环(定时+手动)
这篇文章主要介绍了Android 使用viewpager实现无限循环(定时+手动)的相关资料,需要的朋友可以参考下2015-11-11Android RecyclerView网格布局(支持多种分割线)详解(2)
这篇文章主要为大家详细介绍了Android RecyclerView网格布局,支持多种分割线,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2017-02-02
最新评论