Android实现滑动加载数据的方法

所属分类: 软件编程 / Android 阅读数: 1607
收藏 0 赞 0 分享

本文实例讲述了Android实现滑动加载数据的方法。分享给大家供大家参考。具体实现方法如下:

EndLessActivity.java如下:

package com.ScrollListView;
import Android.app.ListActivity;
import Android.os.Bundle;
import Android.view.Gravity;
import Android.view.View;
import Android.view.ViewGroup;
import Android.widget.AbsListView;
import Android.widget.BaseAdapter;
import Android.widget.LinearLayout;
import Android.widget.ProgressBar;
import Android.widget.TextView;
import Android.widget.AbsListView.OnScrollListener;
public class EndLessActivity extends ListActivity implements OnScrollListener {
 Aleph0 adapter = new Aleph0();
  int mProgressStatus = 0 ;
 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);
  setListAdapter(adapter); 
  getListView().setOnScrollListener( this );
 }
  public void onScroll(AbsListView view,
   int firstVisible, int visibleCount, int totalCount) {
   boolean loadMore = /* maybe add a padding */
   firstVisible + visibleCount >= totalCount;
   if (loadMore) {
   adapter.count += visibleCount; // or any other amount 
   adapter.notifyDataSetChanged();
  }
 }
  public void onScrollStateChanged(AbsListView v, int s) { } 
  class Aleph0 extends BaseAdapter {
   int count = 40 ; /* starting amount */
   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(EndLessActivity. this );
    view.setText( " entry " + pos);
     return view;
  }
 }
}

listview下部是按钮控制:

package com.ScrollListView;
import Android.app.ListActivity;
import Android.os.Bundle;
import Android.view.Gravity;
import Android.view.View;
import Android.view.ViewGroup;
import Android.widget.AbsListView;
import Android.widget.BaseAdapter;
import Android.widget.Button;
import Android.widget.LinearLayout;
import Android.widget.ProgressBar;
import Android.widget.TextView;
import Android.widget.AbsListView.OnScrollListener;
public class EndLessActivity extends ListActivity {
 Aleph0 adapter = new Aleph0();
  int mProgressStatus = 0 ;
  protected void onCreate(Bundle savedInstanceState) {
   super .onCreate(savedInstanceState);
  LinearLayout searchLayout = new LinearLayout( this );
  searchLayout.setOrientation(LinearLayout.HORIZONTAL);
    Button textView = new Button( 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);
    textView.setOnClickListener( new Button.OnClickListener()
    {  @Override 
     public void onClick(View v) 
    {  
     adapter.count += 10 ; 
     adapter.notifyDataSetChanged();
     }  
    }); 
  setListAdapter(adapter); 
   // getListView().setOnScrollListener(this); 
 }
 /* public void onScroll(AbsListView view,
  int firstVisible, int visibleCount, int totalCount) {
  boolean loadMore = 
   firstVisible + visibleCount >= totalCount;
  if(loadMore) {
   adapter.count += visibleCount; 
   adapter.notifyDataSetChanged();
  }
 } */
  public void onScrollStateChanged(AbsListView v, int s) { } 
  class Aleph0 extends BaseAdapter {
   int count = 40 ; /* starting amount */
   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(EndLessActivity. this );
    view.setText( " entry " + pos);
     return view;
  }
 }
}

希望本文所述对大家的Android程序设计有所帮助。

更多精彩内容其他人还在看

Retrofit2日志拦截器的使用

这篇文章主要介绍了Retrofit2日志拦截器的使用,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

Android创建外部lib库及自定义View的图文教程

这篇文章主要给大家介绍了关于Android创建外部lib库及自定义View的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

Android分享微信小程序失败的一些事小结

这篇文章主要给大家介绍了关于Android分享微信小程序失败一些事,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

Android分享微信小程序技巧之图片优化

这篇文章主要给大家介绍了关于Android分享微信小程序技巧之图片优化的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

Android Viewpager实现无限循环轮播图

这篇文章主要为大家详细介绍了Android Viewpager实现无限循环轮播图,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android中的Bitmap序列化失败的解决方法

这篇文章主要介绍了Android中的Bitmap序列化失败的解决方法,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
收藏 0 赞 0 分享

Android自定义通用标题栏CustomTitleBar

这篇文章主要为大家详细介绍了Android自定义通用标题栏CustomTitleBar,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android组合控件自定义标题栏

这篇文章主要为大家详细介绍了Android组合控件自定义标题栏,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android自定义复合控件实现通用标题栏

这篇文章主要为大家详细介绍了Android自定义复合控件实现通用标题栏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

ExpandableListView实现简单二级列表

这篇文章主要为大家详细介绍了ExpandableListView实现简单二级列表,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享
查看更多