前言:在前面的基础上,进一步更改代码,让用户自己到底刷新的办法我觉得不太好,一般情况下,点击刷新还得等一会,倒不如直接快到底的时候自己自动加载内容,为了实现这个功能就要判断当前显示的ITEM是不是到底了,如果到底了就调用加载函数,为了实现在主页面中调用程序,我们又再一次的用到了接口;
相关文章:
1、《List控件使用--SimpleAdapter使用详解(一)》
2、《List控件使用--SimpleAdapter使用详解(二)》
3、《PullToRefresh使用详解(一)--构建下拉刷新的listView》
4、《PullToRefresh使用详解(二)---重写BaseAdapter实现复杂XML下拉刷新》
5、《PullToRefresh使用详解(三)--实现异步加载的下拉刷新列表》
6、《PullToRefresh使用详解(四)--利用回调函数实现到底加载》
7、《PullToRefresh使用详解(五)--下拉刷新的ScrollView》
效果:
当快到底的时候,程序会自动加载后面的列表
这篇较上篇的改动:
1、去掉了线程互斥加载,直接开线程加载当前IMG,即不判断当前用户是不是在划屏了啥啥的,只要调用到getView()一概加载;
2、重写了ImageAndTextListAdapter类;
全部代码:
package com.example.try_simpleadapter_new; import java.util.ArrayList; import java.util.List; import com.example.try_simpleadapter_new.AsyncImageLoader.ImageCallback; import com.handmark.pulltorefresh.library.PullToRefreshListView; import android.R.bool; import android.app.Activity; import android.graphics.drawable.Drawable; import android.graphics.drawable.Drawable.Callback; import android.util.Log; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.view.ScaleGestureDetector.OnScaleGestureListener; import android.widget.AbsListView; import android.widget.BaseAdapter; import android.widget.ImageView; import android.widget.ListView; import android.widget.TextView; public class ImageAndTextListAdapter extends BaseAdapter{ private LayoutInflater inflater; private ListView listView; private AsyncImageLoader asyncImageLoader; private List<ImageAndText> dataArray=new ArrayList<ImageAndText>(); private ScrollToLastCallBack mScrollToLastCallBack=null; public ImageAndTextListAdapter(Activity activity, List<ImageAndText> imageAndTexts, ListView listView,final ScrollToLastCallBack scrollToLastCallBack) { this.listView = listView; asyncImageLoader = new AsyncImageLoader(); inflater = activity.getLayoutInflater(); dataArray=imageAndTexts; mScrollToLastCallBack=scrollToLastCallBack; } public interface ScrollToLastCallBack { public void onScrollToLast(Integer pos); } @Override public int getCount() { // TODO Auto-generated method stub return dataArray.size(); } @Override public Object getItem(int position) { // TODO Auto-generated method stub if(position >= getCount()){ return null; } return dataArray.get(position); } @Override public long getItemId(int position) { // TODO Auto-generated method stub return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { if (convertView == null) { convertView = inflater.inflate(R.layout.item, null); } convertView.setTag(position); ImageAndText imageAndText = (ImageAndText) getItem(position); String imageUrl = imageAndText.getImageUrl(); TextView nameView = (TextView) convertView.findViewById(R.id.name); nameView.setText(imageAndText.getName()); TextView infoView = (TextView) convertView.findViewById(R.id.info); infoView.setText(imageAndText.getInfo()); ImageView iv = (ImageView) convertView.findViewById(R.id.img); iv.setBackgroundResource(R.drawable.rc_item_bg); // 加载IMG,并设定到ImageView中 asyncImageLoader.loadDrawable(position,imageUrl, new ImageCallback() { @Override public void onImageLoad(Integer pos, Drawable drawable) { Log.d("msg",pos+ "正在贴"); View view = listView.findViewWithTag(pos); if(view != null){ ImageView iv = (ImageView) view.findViewById(R.id.img); iv.setBackgroundDrawable(drawable); Log.d("msg","贴成功了"); } } //加载不成功的图片处理 @Override public void onError(Integer pos) { View view = listView.findViewWithTag(pos); if(view != null){ ImageView iv = (ImageView) view.findViewById(R.id.img); iv.setBackgroundResource(R.drawable.rc_item_bg); } Log.d("msg","没贴成功"); } }); //判断当前列表所在位置,当到最后两项时就加载 int end=listView.getLastVisiblePosition(); if(end>getCount()-3&&end<getCount()-1&&end<=getCount()) { mScrollToLastCallBack.onScrollToLast(position); } return convertView; } }1、第一个改动,增加了接口
public interface ScrollToLastCallBack { public void onScrollToLast(Integer pos); }2、ImageAndTextListAdapter构造函数
public ImageAndTextListAdapter(Activity activity, List<ImageAndText> imageAndTexts, ListView listView,final ScrollToLastCallBack scrollToLastCallBack) { this.listView = listView; asyncImageLoader = new AsyncImageLoader(); inflater = activity.getLayoutInflater(); dataArray=imageAndTexts; mScrollToLastCallBack=scrollToLastCallBack; }增加了ScrollToLastCallBack的传递,说明在构造ImageAndTextListAdapter变量时,要传进来ScrollToLastCallBack回调函数的实例,咱们看看这个函数在哪里调用
//判断当前列表所在位置,当到最后两项时就加载 int end=listView.getLastVisiblePosition(); if(getCount()-2<=end&&end<=getCount()) { mScrollToLastCallBack.onScrollToLast(position); }在getView(……)函数中,首先获得当前的显示位置,如果当前的显示位置在最后两个ITEM里了,这里就调用mScrollToLastCallBack.onScrollToLast(position)回调函数,下面我们再看看这个回调函数传进去的时候是怎么写的。
这里我们只看OnCreate()函数,其它地方都没变
public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); mPullRefreshListView = (PullToRefreshListView) findViewById(R.id.pull_refresh_list); //设定下拉监听函数 mPullRefreshListView.setOnRefreshListener(new OnRefreshListener<ListView>() { @Override public void onRefresh(PullToRefreshBase<ListView> refreshView) { String label = DateUtils.formatDateTime(getApplicationContext(), System.currentTimeMillis(), DateUtils.FORMAT_SHOW_TIME | DateUtils.FORMAT_SHOW_DATE | DateUtils.FORMAT_ABBREV_ALL); // Update the LastUpdatedLabel refreshView.getLoadingLayoutProxy().setLastUpdatedLabel(label); // Do work to refresh the list here. new GetDataTask().execute(); } }); // 当用户拉到底时调用 mPullRefreshListView.setOnLastItemVisibleListener(new OnLastItemVisibleListener() { @Override public void onLastItemVisible() { Toast.makeText(MainActivity.this, "End of List!", Toast.LENGTH_SHORT).show(); // // 到底时加载任务 // new GetDataTask().execute(); } }); //PullToRefreshBase mPullRefreshListView.setMode(Mode.PULL_FROM_START);// 设置底部下拉刷新模式 //传参生成适配器 mData = getData(); ListView actualListView = mPullRefreshListView.getRefreshableView(); //自己写的回调函数,监听当前列表是否到了倒数第二个列表项 ScrollToLastCallBack scrollToLastCallBack=new ScrollToLastCallBack(){ @Override public void onScrollToLast(Integer pos) { // TODO Auto-generated method stub Toast.makeText(MainActivity.this, "到倒数第二个了,加载哈", Toast.LENGTH_SHORT).show(); // 到底时加载任务 new GetDataTask().execute(); } }; adapter = new ImageAndTextListAdapter(this,mData,actualListView,scrollToLastCallBack); // 设置适配器 actualListView.setAdapter(adapter); }这里的变动在最下面,看这段代码:
//自己写的回调函数,监听当前列表是否到了倒数第二个列表项 ScrollToLastCallBack scrollToLastCallBack=new ScrollToLastCallBack(){ @Override public void onScrollToLast(Integer pos) { // TODO Auto-generated method stub Toast.makeText(MainActivity.this, "到倒数第二个了,加载哈", Toast.LENGTH_SHORT).show(); // 到底时加载任务 new GetDataTask().execute(); } }; adapter = new ImageAndTextListAdapter(this,mData,actualListView,scrollToLastCallBack);先构造一个scrollToLastCallBack回调函数,函数内容就是当到倒数第二个ITEM时提示,然后执行加载任务(GetDataTask()),最后将其传到ImageAndTextListAdapter构造函数中。
OK,到这就结束了,其实就是一个回调函数的书写,难度不大,只是在涉及代码量大了的话就相对来讲有点小难度了。
更正声明:
原来这段代码:
int end=listView.getLastVisiblePosition(); if(getCount()-2<=end&&end<=getCount()) { mScrollToLastCallBack.onScrollToLast(position); }
所存在的问题:我原本打算到倒数第二个ITEM出现时自动加载列表,但这里没能准确定位到倒数第二个ITEM,当倒数第一个ITEM出现时仍然符合条件,致使加载两次,有时出现列表重复的情况;下面更改
int end=listView.getLastVisiblePosition(); if(end>getCount()-3&&getCount()-1<end&&end<=getCount()) { mScrollToLastCallBack.onScrollToLast(position); }
最后,源码来啦:http://download.csdn.net/detail/harvic880925/6804687 (不要分,仅供分享)
请大家尊重原创者版权,转载请标明出处:http://blog.csdn.net/harvic880925/article/details/17792755 ,谢谢!!