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程序设计有所帮助。

时间: 2024-09-18 03:46:54

Android编程实现ListView滚动提示等待框功能示例的相关文章

Android编程实现变化的双重选择框功能示例

本文实例讲述了Android编程实现变化的双重选择框功能.分享给大家供大家参考,具体如下: 原理:定义四个RadioGroup,通过第一个RadioGroup的选择来控制其余几个radiogroup的显隐 布局: <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android&quo

Android编程实现对电池状态的监视功能示例_Android

本文实例讲述了Android编程实现对电池状态的监视功能.分享给大家供大家参考,具体如下: 最近在开发一个与GPS相关的项目,因为其中涉及到了GPS的使用,众所周知,GPS是相当耗电的,因此就想着怎么能知道当前的电量,并且在电量达到一个下限的时候,及时提醒给用户,以根据情况关闭GPS,节省电量,以备电话急用,后来查资料,看API,终于找到了方法,怎么来监视电量,根据电量的变化来获取当前的电量多少,并且根据其它状态综合对手机进行管理,以达到管理最优的状态. 下面是代码: private Broad

Android编程实现TCP、UDP客户端通信功能示例_Android

本文实例讲述了Android编程实现TCP.UDP客户端通信功能.分享给大家供大家参考,具体如下: 在进行Android开发的过程中,免不了,要开发TCP/UDP通讯的程序,下面这两段代码,分别介绍了TCP/UCP通过的一个实例: 代码一 TCP通讯: private void tcpdata() { try { Socket s = new Socket("192.168.0.25", 65500); // outgoing stream redirect to socket Out

Android编程实现TCP、UDP客户端通信功能示例

本文实例讲述了Android编程实现TCP.UDP客户端通信功能.分享给大家供大家参考,具体如下: 在进行Android开发的过程中,免不了,要开发TCP/UDP通讯的程序,下面这两段代码,分别介绍了TCP/UCP通过的一个实例: 代码一 TCP通讯: private void tcpdata() { try { Socket s = new Socket("192.168.0.25", 65500); // outgoing stream redirect to socket Out

Android编程记录ListView标记行状态的方法

本文实例讲述了Android编程记录ListView标记行状态的方法.分享给大家供大家参考,具体如下: 小Demo无什么特别之处,最特别的就是尽量少用notifyDataSetChanged,开销太大了,当然使用是会省不少工的,不过有时候还是会遇到别的问题的,项目经验表示会有这个可能性的,废话不多少了,直接上关键代码. @Override public void onItemClick(AdapterView<?> adapterView, View view, int pos, long a

Android编程实现ListView头部ViewPager广告轮询图效果_Android

本文实例讲述了Android编程实现ListView头部ViewPager广告轮询图效果.分享给大家供大家参考,具体如下: 之前看了别人的一些软件,发现其广告图轮询的时候,那个广告感觉和ViewPager的效果不太一样,后来也查了一下,是因为时间问题,找了一些资料,自己也实践一下. 1.为了解决ListView头部加ViewPager滑动冲突问题,必须自定义ListView,重写里面的onInterceptTouchEvent方法,ListView代码如下: package com.exampl

Android编程实现Listview点击展开和隐藏的方法_Android

本文实例讲述了Android编程实现Listview点击展开和隐藏的方法.分享给大家供大家参考,具体如下: 代码较多,所以找关键点大家贴出来,相信大家看了之后很容易就明白的, 在listview的activity中 List<Map<String, Object>> listItems = new ArrayList<Map<String, Object>>() myAdapter = new MyAdapter(getApplicationContext(

Android编程实现大图滚动显示的方法_Android

本文实例讲述了Android编程实现大图滚动显示的方法.分享给大家供大家参考,具体如下: 问题: 我有一张比较大的图片,比如长宽都是屏幕的两倍大小,我想实现的功能是首先将图片居中显示,由于图片太大显然只能显示一部分,然后可以通过拖动,实现图片的平滑滚动(既看不出来滚动刷新痕迹). 就像google地图一样,如果用mapView这个控件,那么可以在屏幕上拖动整个地图,但是由于地图信息量太大,如果一次拖动过快,那么屏幕会暂时显示出一些刷新痕迹(灰白的格子). 想使用mapView来加载已有图片,但是

Android编程使用ListView实现数据列表显示的方法_Android

本文实例讲述了Android编程使用ListView实现数据列表显示的方法.分享给大家供大家参考,具体如下: 要将数据库中的数据列表显示在屏幕上,我们要使用ListView这个控件,当用户从数据库中取出数据时,要将数据绑定到显示控件上,如何绑定呢,我们需要创建适配器进行绑定,创建适配器有两种方式: 第一种是用SimpleAdapter创建(要求绑定的数据是List<HashMap<String, Object>>数据类型) 第二种是用SimpleCursorAdapter创建(要求