アプリケーションでプルトリフレッシュ リストビューを使用しています。以下のコードはこれを示しています
listView.setOnRefreshListener(new OnRefreshListener() {
// @Override
public void onRefresh() {
// Your code to refresh the list contents goes here
listView.setAdapter(null);
scroll=true;
pic.clear();
id.clear();
name.clear();
msg.clear();
img.clear();
profimg.clear();
objid.clear();
comment.clear();
weburl.clear();
adapter.clear();
likes.clear();
like_or_unlike.clear();
previousTotal = 0;
listView.removeFooterView(footerView);
// listView.setAdapter(null);
// scroll=true;
// notifyDataSetChanged();
// urlval=0;
j=0;
loading = true;
webserv="https://graph.facebook.com/me/home?access_token="+accesstoken;
doInBack dob=new doInBack();
dob.execute();
// doback(webserv);
Log.e("hi","doback called");
// Make sure you call listView.onRefreshComplete()
// when the loading is done. This can be done from here or any
// other place, like on a broadcast receive from your loading
// service or the onPostExecute of your AsyncTask.
// For the sake of this sample, the code will pause here to
// force a delay when invoking the refresh
}
});
この Asyntask を呼び出すと、すぐに 1 つのアイテムが追加されますが、これは表示されません。これは、より多くのデータをロードするために使用した onScrollListener クラスで観察されました。
私の onScrollListener クラスは
listView.setOnScrollListener(new OnScrollListener() {
private int threshold = 0;
//
public void onScrollStateChanged(AbsListView view, int scrollState) {
////
if (scrollState != 0) {
isScrolling = true;
}
else {
isScrolling = false;
adapter.notifyDataSetChanged();
}
}
public void onScroll(AbsListView view, int firstVisibleItem,int visibleItemCount, int totalItemCount)
{
// public void onScrollStateChanged(AbsListView view , int scrollState)
// {
// if (scrollState != 0) {
// listView.getAdapter().isScrolling = true;
// }
// else {
// listView.getAdapter().isScrolling = false;
// listView.getAdapter().notifyDataSetChanged();
// }
// }
// TODO Auto-generated method stub
if (loading) {
if (totalItemCount > previousTotal) {
Log.e("in loading","in load");
loading = false;
previousTotal = totalItemCount;
}
}
// int lastInScreen = firstVisibleItem + visibleItemCount;
// if (!loading && (totalItemCount - visibleItemCount) ==(firstVisibleItem + threshold)){
if (!loading && (firstVisibleItem + visibleItemCount) >= totalItemCount){
// if(((firstVisibleItem + visibleItemCount) == totalItemCount)){
// if (!(loading) &&(totalItemCount - visibleItemCount) ==(firstVisibleItem + threshold)) {
// clearAllResources();
System.out.println(firstVisibleItem );
System.out.println(visibleItemCount );
System.out.println(totalItemCount);
scroll=false;
// if (!(loading) &&(totalItemCount - visibleItemCount) == (firstVisibleItem + threshold)) {
Log.v("in gridview loading more","grid load");
//
doInBack dob=new doInBack();
dob.execute();
// doback(webserv);
loading = true;
}
}
});
doInBack dob=new doInBack();
dob.execute();
// doback(webserv);
Log.e("hi","doback called");
}
AsyncTask の呼び出し時にアイテムを一時的に追加する理由が本当にわかりませんでした。助けてください。よろしくお願いします