Android編程實現(xiàn)ListView滾動提示等待框功能示例
本文實例講述了Android編程實現(xiàn)ListView滾動提示等待框功能。分享給大家供大家參考,具體如下:
其實原理很簡單,只需要設(shè)置監(jiān)聽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); 設(shè)置每次最后一行被選中
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>
更多關(guān)于Android相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Android視圖View技巧總結(jié)》、《Android布局layout技巧總結(jié)》、《Android圖形與圖像處理技巧總結(jié)》、《Android開發(fā)入門與進(jìn)階教程》、《Android調(diào)試技巧與常見問題解決方法匯總》、《Android多媒體操作技巧匯總(音頻,視頻,錄音等)》、《Android基本組件用法總結(jié)》及《Android控件用法總結(jié)》
希望本文所述對大家Android程序設(shè)計有所幫助。
- Android ListView滾動到指定的位置
- Android ListView滾動到底后自動加載數(shù)據(jù)
- Android基于ListView實現(xiàn)類似QQ空間的滾動翻頁與滾動加載效果
- Android簡單記錄和恢復(fù)ListView滾動位置的方法
- Android程序開發(fā)之ListView實現(xiàn)橫向滾動(帶表頭與固定列)
- Android開發(fā)ListView中下拉刷新上拉加載及帶列的橫向滾動實現(xiàn)方法
- Android程序開發(fā)ListView+Json+異步網(wǎng)絡(luò)圖片加載+滾動翻頁的例子(圖片能緩存,圖片不錯亂)
- android ListView的右邊滾動滑塊啟用方法 分享
- android listview 水平滾動和垂直滾動的小例子
- android ListView自動滾動方法
- android開發(fā)之橫向滾動/豎向滾動的ListView(固定列頭)
相關(guān)文章
android使用FlipAnimation實現(xiàn)3D垂直翻轉(zhuǎn)動畫
這篇文章主要為大家詳細(xì)介紹了android使用FlipAnimation實現(xiàn)3D垂直翻轉(zhuǎn)動畫,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-12-12
Android實現(xiàn)無標(biāo)題欄全屏的方法
這篇文章主要介紹了Android實現(xiàn)無標(biāo)題欄全屏的三種方法,感興趣的小伙伴們可以參考一下2016-07-07
Android開發(fā)實現(xiàn)調(diào)節(jié)屏幕亮度功能
這篇文章主要介紹了Android開發(fā)實現(xiàn)調(diào)節(jié)屏幕亮度功能,涉及Android權(quán)限控制及屏幕亮度相關(guān)屬性操作技巧,需要的朋友可以參考下2018-03-03
Android 使用viewpager實現(xiàn)無限循環(huán)(定時+手動)
這篇文章主要介紹了Android 使用viewpager實現(xiàn)無限循環(huán)(定時+手動)的相關(guān)資料,需要的朋友可以參考下2015-11-11
Android RecyclerView網(wǎng)格布局(支持多種分割線)詳解(2)
這篇文章主要為大家詳細(xì)介紹了Android RecyclerView網(wǎng)格布局,支持多種分割線,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-02-02

