作者:Sanvi 邮箱:sanvibyfish@gmail.com 转载请注明来源!
实现原理
通过手指的滑动,判断数据大小
然后动态改变数据
底部的加载是一个view
import android.app.ListActivity;
import android.os.Bundle;
import android.os.Handler;
import android.view.Gravity;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AbsListView;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.ProgressBar;
import android.widget.TextView;
import android.widget.AbsListView.OnScrollListener;
import android.widget.LinearLayout.LayoutParams;
public class Test extends ListActivity implements OnScrollListener {
Aleph0 adapter = new Aleph0();
int lastItem = 0;
int mProgressStatus = 0;
private Handler mHandler = new Handler();
ProgressBar progressBar;
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
LinearLayout searchLayout = new LinearLayout(this);
searchLayout.setOrientation(LinearLayout.HORIZONTAL);
progressBar = new ProgressBar(this);
progressBar.setPadding(0, 0, 15, 0);
searchLayout.addView(progressBar,new LinearLayout.LayoutParams(
LinearLayout.LayoutParams.WRAP_CONTENT,
LinearLayout.LayoutParams.WRAP_CONTENT
));
TextView textView = new TextView(this);
textView.setText("加载中...");
textView.setGravity(Gravity.CENTER_VERTICAL);
searchLayout.addView(textView,new LinearLayout.LayoutParams(
LinearLayout.LayoutParams.FILL_PARENT,
LinearLayout.LayoutParams.FILL_PARENT
));
searchLayout.setGravity(Gravity.CENTER);
LinearLayout loadingLayout = new LinearLayout(this);
loadingLayout.addView(searchLayout,new LinearLayout.LayoutParams(
LinearLayout.LayoutParams.WRAP_CONTENT,
LinearLayout.LayoutParams.WRAP_CONTENT
));
loadingLayout.setGravity(Gravity.CENTER);
getListView().addFooterView(loadingLayout);
// Start lengthy operation in a background thread
// new Thread(new Runnable() {
// public void run() {
// while (mProgressStatus < 100) {
//
// // Update the progress bar
// mHandler.post(new Runnable() {
// public void run() {
// progressBar.setProgress(mProgressStatus);
// }
// });
// }
// }
// }).start();
registerForContextMenu(getListView());
setListAdapter(adapter);
getListView().setOnScrollListener(this);
}
public void onScroll(AbsListView v, int firstVisibleItem, int visibleItemCount, int totalItemCount) {
lastItem = firstVisibleItem + visibleItemCount - 1 ;
System.out.println("lastItem:" + lastItem);
}
public void onScrollStateChanged(AbsListView v, int state) {
if(lastItem == adapter.count && state == OnScrollListener.SCROLL_STATE_IDLE){
adapter.count += 10;
adapter.notifyDataSetChanged();
}
// if(state == OnScrollListener.SCROLL_STATE_IDLE ) {
// adapter.count += 10;
// adapter.notifyDataSetChanged();
// }
}
class Aleph0 extends BaseAdapter {
int count = 10;
public int getCount() { return count; }
public Object getItem(int pos) { return pos; }
public long getItemId(int pos) { return pos; }
public View getView(int pos, View v, ViewGroup p) {
TextView view = new TextView(Test.this);
view.setText("entry " + pos);
view.setHeight(90);
return view;
}
}
}
相关推荐
Android ListView 滑动分页 分页加载数据
android按钮分页与滑动分页
android gridview分页和滑动效
http://blog.csdn.net/icqapp/article/details/24978057 详看效果图...android listview左右滑动分页(viewpager嵌套listview进行分页),焦点图带圆焦点 先敬告学者:如在此项目上运行不了的直接找到本人QQ:508181017,
安卓Android源码——安卓Android Launcher 桌面分页滑动代码.rar
android 基于ViewPager的下tab滑动分页效果
android的分页加载是非常有用且非常常见的功能,我对分页加载做了一个例子很实用,希望能给你带来帮助。
android Listview下拉刷新 上拉(滑动分页)加载更多 高仿新浪微博下拉刷新,同时实现了滑动加载下一页
可以垂直分页滑动的android应用源码
Android viewpage 水平滑动分页 加indicator, viewpage 水平滑动分页 加indicator
ListView水平滑动分页,更改属性也可垂直滑动分页,但滑动事件有所冲突
引用滑动菜单的类库,实现的一个简单的demo,另外附加实现的一个简单的滑动分页功能
android左右滑动翻页技术的源码,直接下载导入就可以运行
android ListView滑动分页加载和点击分页加载,以及复用convertView综合案例
本文实例讲述了Android滑动动态分页实现方法。分享给大家供大家参考,具体如下: 实现 Android.widget.AbsListView.OnScrollListener 主要代码: private int lastItemIndex; @Override public void onScroll...
主要介绍了Android开发中滑动分页功能,结合实例形式详细分析了Android滑动分页功能的具体步骤与相关实现技巧,代码中备有详尽的注释便于理解,需要的朋友可以参考下
要实现翻页滑动首先我们要确定是向前翻页还是向后翻页,这里通过记录开始翻页前当前的位置和滑动后的位置比较即可得知,下面选择手指触摸按下时滑动的位置为当前开始滑动位置: //当前滑动距离 private int ...
仿Metro效果,页面分两部分,左边是ViewPager滑动分页,每个磁贴上包含文字和图片,右边是固定的文字图片。希望对各位学习有帮助。