android中listview分页载入数据

android中listview分页载入数据

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

android中listview分页载入数据此处内容已经被作者隐藏,请输入验证码查看内容
验证码:
请关注本站微信公众号,回复“”,获取验证码。在微信里搜索“”或者“”或者微信扫描右侧二维码都可以关注本站微信公众号。

               前段时间做的新浪微博项目一直想实现listview分页载入数据,今天最终实现了,哈哈!感觉挺好的,今天又写了个demo给大家分享下。

              首先说下listview的优化方案,这也是面试中常考的题目。优化方案有三种:1,假设自己定义适配器,那么在getView方法中推断contentView是否为空,假设为空创建contentView并返回,假设不为空直接返回contentView。这样能尽可能少创建view。2.给contentView设置tag,传入一个viewHoder对象,用于缓存要实现的数据。3,假设listview中显示的item太多,就要考虑分页载入了。

               以下就注意介绍一下分页载入数据。首先在layout下创建listview.xml:

           

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >

    <ListView
        android:id="@+id/listView1"
        android:layout_width="match_parent"
        android:layout_height="wrap_content" >
    </ListView>

</LinearLayout>

          然后创建listview_item.xml:

          

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
    android:orientation="vertical"  
    android:layout_width="fill_parent"  
    android:layout_height="fill_parent">  
    <TextView  
        android:id="@+id/list_item_text"  
        android:layout_width="fill_parent"  
        android:layout_height="fill_parent"  
        android:gravity="center"  
        android:textSize="20sp"  
        android:paddingTop="10dp"  
        android:paddingBottom="10dp"/>  
</LinearLayout>  

           再为跟多button加入一个xml:

      

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:gravity="center"
    android:orientation="vertical" >

    <Button
        android:id="@+id/loadMoreButton"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:onClick="loadMore"
        android:text="载入很多其它" />

</LinearLayout>

     

           代码部分:

       

public class ListViewAdapter extends BaseAdapter {

	private static Map<Integer,View> m=new HashMap<Integer,View>();
	
	private List<String> items;
	private LayoutInflater inflater;
	
	public ListViewAdapter(List<String> items, Context context) {
		super();
		this.items = items;
		this.inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
	}

	@Override
	public int getCount() {
		// TODO Auto-generated method stub
		return items.size();
	}

	@Override
	public Object getItem(int position) {
		// TODO Auto-generated method stub
		return items.get(position);
	}

	@Override
	public long getItemId(int position) {
		// TODO Auto-generated method stub
		return position;
	}

	@Override
	public View getView(int position, View contentView, ViewGroup arg2) {
		// TODO Auto-generated method stub
		contentView=m.get(position);
		if(contentView==null){
			contentView=inflater.inflate(R.layout.listview_item, null);
			TextView text=(TextView) contentView.findViewById(R.id.list_item_text);
			text.setText(items.get(position));
		}
		m.put(position, contentView);
		return contentView;
	}
	
	public void addItem(String item) {  
        items.add(item);  
    }  

}

         

public class ListViewActivity extends Activity implements OnScrollListener  {
	  List<String> items = new ArrayList<String>();  
	 private ListView listView;  
	    private int visibleLastIndex = 0;   //最后的可视项索引  
	    private int visibleItemCount;       // 当前窗体可见项总数  
	    private ListViewAdapter adapter;  
	    private View loadMoreView;  
	    private Button loadMoreButton;  
	    private Handler handler = new Handler();  
	  
	    @Override  
	    public void onCreate(Bundle savedInstanceState) {  
	        super.onCreate(savedInstanceState);  
	        setContentView(R.layout.listview);  
	          
	        loadMoreView = getLayoutInflater().inflate(R.layout.load_more, null);  
	        loadMoreButton = (Button) loadMoreView.findViewById(R.id.loadMoreButton);  
	        loadMoreButton.setOnClickListener(new OnClickListener() {
				
				@Override
				public void onClick(View v) {
					// TODO Auto-generated method stub
					loadMoreButton.setText("正在载入...");   //设置button文字loading  
			        handler.postDelayed(new Runnable() {  
			            @Override  
			            public void run() {  
			                  
			                loadData();  
			                  
			                adapter.notifyDataSetChanged(); //数据集变化后,通知adapter  
			                listView.setSelection(visibleLastIndex - visibleItemCount + 1); //设置选中项  
			                  
			                loadMoreButton.setText("载入很多其它");    //恢复button文字  
			            }  
			        }, 1000);  
				}
			});
	        listView = (ListView) this.findViewById(R.id.listView1);
	          
	        listView.addFooterView(loadMoreView);   //设置列表底部视图  
	       // listView.addHeaderView(v)    //设置列表顶部视图
	  
	        initAdapter();  
	          
	        listView.setAdapter(adapter);                //自己主动为id是list的ListView设置适配器  
	          
	        listView.setOnScrollListener(this);     //加入滑动监听  
	        listView.setOnItemClickListener(new OnItemClickListener() {

				@Override
				public void onItemClick(AdapterView<?> arg0, View view,
						int position, long arg3) {
					// TODO Auto-generated method stub
					Toast.makeText(getApplicationContext(), items.get(position),Toast.LENGTH_SHORT).show();
				}
			});
	    }  
	      
	    /** 
	     * 初始化适配器 
	     */  
	    private void initAdapter() {  
	     
	        for (int i = 0; i < 20; i++) {  
	            items.add(String.valueOf(i + 1));  
	        }  
	        adapter = new ListViewAdapter(items,this);  
	    }  
	  
	    /** 
	     * 滑动时被调用 
	     */  
	    @Override  
	    public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {  
	        this.visibleItemCount = visibleItemCount;  
	        visibleLastIndex = firstVisibleItem + visibleItemCount - 1;  
	    }  
	  
	    /** 
	     * 滑动状态改变时被调用 
	     */  
	    @Override  
	    public void onScrollStateChanged(AbsListView view, int scrollState) {  
	        int itemsLastIndex = adapter.getCount() - 1;    //数据集最后一项的索引  
	        int lastIndex = itemsLastIndex + 1;             //加上底部的loadMoreView项  
	        if (scrollState == OnScrollListener.SCROLL_STATE_IDLE && visibleLastIndex == lastIndex) {  
	            //假设是自己主动载入,能够在这里放置异步载入数据的代码  
	            Log.i("LOADMORE", "loading...");  
	        }  
	    }  
	      

	    /** 
	     * 模拟载入数据 
	     */  
	    private void loadData() {  
	        int count = adapter.getCount();  
	        for (int i = count; i < count + 20; i++) {  
	            adapter.addItem(String.valueOf(i + 1));  
	        }  
	    }

		
}

           最后看看效果:

         android中listview分页载入数据

       android中listview分页载入数据

       

       

        android中listview分页载入数据

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/117903.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 简单理解Binder机制的原理

    一、概述Android系统中,涉及到多进程间的通信底层都是依赖于BinderIPC机制。例如当进程A中的Activity要向进程B中的Service通信,这便需要依赖于BinderIPC。不仅于此,整个Android系统架构中,大量采用了Binder机制作为IPC(进程间通信)方案。当然也存在部分其他的IPC方式,如管道、SystemV、Socket等。那么Android为什么不使用这…

  • 【西安xxx面经】

    【西安xxx面经】我是在线下一天面完的,总共有五面。一面:自我介绍,问题基本上都是根据简历上问的,我简历上写了算法和数据结构所以问题都是和这些相关。一面有两个面试官,先问了面向对象的思想,面向对象的三大特性,分别解释一下。然后就是数据结构方面的知识:栈,队列,哈希表,如果数据很多的话用哈希表怎么存储。手撕二分,然后手撕一个关于链表的题:现在有很多节点,每个节点都有它在链表中的编号,现在要按照编号将这个链表复原。(因为面试官没有c++环境,所以我用的记事本编程,需要讲出来思路,每一句的作用)。面试体验:两个面试官还是有压力

  • IIS真正能用的ISAPI-Rewrite防盗链规则写法

    IIS真正能用的ISAPI-Rewrite防盗链规则写法本规则支持白名单排除式防盗链,搜索引擎友好不屏蔽,被盗链后的错误提示转向,支持各种文件类型,经作者亲验真的能用,第一时间在原创发表,请继续往下阅读。近来小站遇到了盗链问题,至使网站的流量枉费流失,于是被迫准备为服务器安装防盗链机制以挽救本就不宽裕的带宽。通过G.CN和B.CN搜索后得出了几种不同的方案,例如网站程序的URL伪装法、服务器端的收费插件法和ISAPI-R…

  • 一维卷积神经网络处理序列模型

    一维卷积神经网络处理序列模型fromkeras.datasetsimportimdbfromkeras.modelsimportSequentialfromkeras.layersimportEmbedding,Conv1D,MaxPooling1D,GlobalMaxPooling1D,Densefromkeras.optimizersimportRMSpropmax_featu…

  • openwrt外网web管理_OpenAPI

    openwrt外网web管理_OpenAPI转自:http://odoodevelop.lofter.com/1.web模块注意,OpenERP模块中web部分用到的所有文件必须被放置在模块内的 static 文件夹里。这是强制性的,出于安全考虑。事实上,我们创建的文件夹CSS,JS和XML,仅仅是一个习惯。static文件夹oepetstore/static/css/petst

    2022年10月28日
  • 使用rapidxml 生成xml文件[通俗易懂]

    使用rapidxml 生成xml文件[通俗易懂]rapidxml是一个快速的xml库,有C++

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号