在Android的无限滚动的ListView [英] Infinite listview scroll in android

查看:198
本文介绍了在Android的无限滚动的ListView的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有个任务做,我必须从本地数据库自定义列表视图,其布局包括2位和第2文本数据显示的数据。

I have a task to do in which I have to show data from a local database to custom listview whose layout includes 2 bitmap and 2 text data.

我曾尝试引用是:
  https://github.com/weixiao1984/Android-Infinite-Scroll-Listview

但它有这么多,是让我困惑。

But it has so much that is making me confused.

推荐答案

试试这个

MainActivity.java

package com.example.endlesslistview;

import java.util.ArrayList;
import android.app.Activity;
import android.os.AsyncTask;
import android.os.Bundle;
import android.view.View;
import android.widget.AbsListView;
import android.widget.ProgressBar;
import android.widget.AbsListView.OnScrollListener;
import android.widget.ListView;


public class MainActivity extends Activity {

    ListView lvTest;
    int index=0;
    ArrayList<ModelClass> model = new ArrayList<ModelClass>();
    AdapterClass adapter;
    ProgressBar progressbar;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        progressbar = (ProgressBar) findViewById(R.id.progressbar);
        lvTest = (ListView) findViewById(R.id.lvTest);
        insertData();
        adapter = new AdapterClass(MainActivity.this, model);
        lvTest.setAdapter(adapter);

        lvTest.setOnScrollListener(new EndlessScrollListener());
    }

    public void insertData(){
        for(int i=0;i<20;i++){
        model.add(new ModelClass("Data "+index, R.drawable.ic_launcher));
        index = index+1;
        }
    }

    public void insertNewData(){
        for(int i=0;i<20;i++){
        model.add(new ModelClass("Data "+index, R.drawable.ic_launcher));
        index = index+1;
        }

        adapter.notifyDataSetChanged();
    }


    public class EndlessScrollListener implements OnScrollListener {

        private int visibleThreshold = 20;
        private int currentPage = 0;
        private int previousTotal = 0;
        private boolean loading = true;

        public EndlessScrollListener() {
        }
        public EndlessScrollListener(int visibleThreshold) {
            this.visibleThreshold = visibleThreshold;
        }

        @Override
        public void onScroll(AbsListView view, int firstVisibleItem,
                int visibleItemCount, int totalItemCount) {
            if (loading) {
                if (totalItemCount > previousTotal) {
                    loading = false;
                    previousTotal = totalItemCount;
                    currentPage++;
                }
            }
            if (!loading && (totalItemCount - visibleItemCount) <= (firstVisibleItem + visibleThreshold)) {
                // I load the next page of gigs using a background task,
                // but you can call any function here.
                new ShowProgress().execute();
                loading = true;
            }
        }

        @Override
        public void onScrollStateChanged(AbsListView view, int scrollState) {
        }
    }

    class ShowProgress extends AsyncTask<Void, Void, Void>{


        @Override
        protected void onPreExecute() {
            progressbar.setVisibility(View.VISIBLE);
        }

        @Override
        protected Void doInBackground(Void... params) {
            // TODO Auto-generated method stub

            try {
                Thread.sleep(3000);
            } catch (InterruptedException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }

            return null;
        }

        @Override
        protected void onPostExecute(Void result) {
            progressbar.setVisibility(View.GONE);
            insertNewData();
        }
    }
}

activity_main.xml中

<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.example.endlesslistview.MainActivity" >

    <ListView
        android:id="@+id/lvTest"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
         >
    </ListView>

    <ProgressBar
        android:id="@+id/progressbar"
        style="?android:attr/progressBarStyle"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center"
        android:visibility="visible" />

</FrameLayout>

AdapterClass.java

package com.example.endlesslistview;
import java.util.ArrayList;

import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.TextView;
import android.widget.Toast;

public class AdapterClass extends BaseAdapter{   
    Context context;
      private static LayoutInflater inflater=null;
      ArrayList<ModelClass> model;

    public AdapterClass(MainActivity mainActivity, ArrayList<ModelClass> model) {
        // TODO Auto-generated constructor stub
        this.model = model;
        context=mainActivity;
         inflater = ( LayoutInflater )context.
                 getSystemService(Context.LAYOUT_INFLATER_SERVICE);
    }
    @Override
    public int getCount() {
        // TODO Auto-generated method stub
        return model.size();
    }

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

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

    public class Holder
    {
        TextView tv;
        ImageView img;
    }
    @Override
    public View getView(final int position, View convertView, ViewGroup parent) {
        // TODO Auto-generated method stub
        Holder holder=new Holder();
        View rowView;       
             rowView = inflater.inflate(R.layout.row_layout, null);
             holder.tv=(TextView) rowView.findViewById(R.id.textView1);
             holder.img=(ImageView) rowView.findViewById(R.id.imageView1);       
         holder.tv.setText(model.get(position).getData());
         holder.img.setImageResource(model.get(position).getImage());         
         rowView.setOnClickListener(new OnClickListener() {            
            @Override
            public void onClick(View v) {
                // TODO Auto-generated method stub
                Toast.makeText(context, "You Clicked "+model.get(position).getData(), Toast.LENGTH_LONG).show();
            }
        });   
        return rowView;
    }

} 

row_layout.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="horizontal"
    android:layout_gravity="center_vertical"
    android:gravity="center_vertical" >

    <ImageView
        android:id="@+id/imageView1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:src="@drawable/ic_launcher" />

    <TextView
        android:id="@+id/textView1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="TextView"
        android:layout_marginRight="10dp" />

</LinearLayout>

ModelClass.java

package com.example.endlesslistview;

public class ModelClass {

    String data;
    int image;

    public ModelClass(String data, int image) {
        this.data = data;
        this.image = image;
    }
    public String getData() {
        return data;
    }
    public void setData(String data) {
        this.data = data;
    }
    public int getImage() {
        return image;
    }
    public void setImage(int image) {
        this.image = image;
    }



}

这篇关于在Android的无限滚动的ListView的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆