XListview上拉刷新,下拉加載

XListView實現上拉刷新,下拉加載數據的功能,此控件於大約兩年前已停止更新維護,我用這個就是從githup(紅字的官網)上下載的一個文件,然後做成一個依賴庫,感興趣的同學可以嘗試下。

依賴庫的使用:File中導入項目(Import Mudole),然後快捷鍵ctrl+shift+alt+s,調出Dependencies選上要依賴的文件,點擊右上+號,第三個選項,選擇要與哪個文件進行關聯,然後點擊ok。

實現思路
/**
* XlistView:就是一個實現了上拉刷新,下拉加載的自定義控件,我們如果集成他,就可以很輕鬆實現這些效果
* 1.搭建XlistView的環境(拷貝資源:java代碼,XML佈局,strings資源,圖片)
* 2.佈局編寫,初始化控件
* 3.初始化數據(一般網絡的數據,進行解析封裝到集合中,去使用)
* 4.相當於listVIew的使用,創建適配器,設置適配器等等,(此時效果不佳)
* 5.要進行XlistVIew設置下拉刷新,上拉加載的開啓操作
* 6.設置XlistVIew設置下拉刷新,上拉加載的監聽操作
* 7.編寫下拉刷新,上拉加載的業務邏輯代碼
* 8.關閉下拉刷新,上拉加載的業務邏輯
* 注意:如果你想把數據放到listVIew頂部,那麼這個數據就放到集合的0的位置就可以了.
* 提示你改佈局,不要動控件的ID,你直接改控件內容即可
*/
這裏寫圖片描述

Xml代碼 注意:包名不能出錯,如果這有問題,會讓你加載佈局的那一行代碼報錯

activity_main.xml:

<ListView
        android:id="@+id/lv"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/hello_world" />

list_item:

<LinearLayout
        android:layout_width="match_parent"
        android:layout_height="80dp"
        android:orientation="vertical" 
        android:layout_toRightOf="@+id/iv"
        android:layout_marginLeft="10dp"
        >

        <TextView
            android:id="@+id/tv_title"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:singleLine="true" 
            android:text="標題"
            />

        <TextView
            android:id="@+id/tv_desc"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:lines="2" 
            android:text="描述"
            />

        <TextView
            android:id="@+id/tv_time"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:singleLine="true" 
            android:layout_gravity="right"
            android:text="時間"
            />
    </LinearLayout>
    <ImageView 
        android:id="@+id/iv"
        android:layout_width="80dp"
        android:layout_height="80dp"
        android:layout_alignParentLeft="true"
        />

Activity代碼實現

MainActivity.java:

import java.io.Reader;
import java.util.ArrayList;
import java.util.List;

import android.annotation.SuppressLint;
import android.app.Activity;
import android.os.AsyncTask;
import android.os.Bundle;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AbsListView;
import android.widget.AbsListView.OnScrollListener;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.ListView;
import android.widget.TextView;

import com.example.day11demo.bean.News;
import com.example.day11demo.bean.NewsData;
import com.example.day11demo.net.NetUtils;
import com.google.gson.Gson;
import com.nostra13.universalimageloader.core.ImageLoader;

@SuppressLint("NewApi")
public class MainActivity extends Activity {

    ListView lv;
    NewsData nd;
    List<News> list;
    MyAdapter adapter;

    // 表示當前加載的頁面
    int mCurrentPage = 1;

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

        // 1、顯示listview控件 加載網絡數據
        lv = (ListView) findViewById(R.id.lv);
        initData();
        adapter = new MyAdapter();
        lv.setAdapter(adapter);

        // listview的滑動監聽 可以用作加載更多
        lv.setOnScrollListener(new OnScrollListener() {

            // 當滑動到最後一個條的時候 listview會從 滾動狀態變成靜止狀態 屬於狀態的改變
            // 所以當listview滑動最後一個條 狀態改變監聽的方法肯定會被調用
            @Override
            public void onScrollStateChanged(AbsListView view, int scrollState) {
                // TODO Auto-generated method stub
                switch (scrollState) {
                case OnScrollListener.SCROLL_STATE_IDLE:
                    if (view.getLastVisiblePosition() == list.size() - 1) {
                        // 先把當前頁面 +1
                        mCurrentPage++;
                        // 調用加載更多方法
                        loadMoreData();
                    }
                    break;

                default:
                    break;
                }
            }

            @Override
            public void onScroll(AbsListView view, int firstVisibleItem,
                    int visibleItemCount, int totalItemCount) {
                // TODO Auto-generated method stub

            }
        });
    }

    private void initData() {
        // 用來讓listview進行顯示的數據集合
        list = new ArrayList<News>();
        // 使用一個加載更多的方法請求10條數據
        loadMoreData();
    }

    // 每次加載10條數據 然後把這十條數據存入一個 list集合中 刷新適配器進行顯示
    private void loadMoreData() {
        new AsyncTask<String, String, NewsData>() {

            @Override
            protected NewsData doInBackground(String... params) {
                // 通過get方式請求 網絡的字符輸入流
                Reader reader = NetUtils
                        .getDataByGet("https://api.tianapi.com/wxnew/?key=8d6e3228d25298f13af4fc40ce6c9679&num=10&page="
                                + mCurrentPage);
                Gson gson = new Gson();
                nd = gson.fromJson(reader, NewsData.class);
                // 因爲該loadmore方法每次加載都是把10條數據轉換成javabean對象
                // 所以我們需要一個單獨的list集合 然後把每次請就回來的javabean中集合的數據 全都拼接到單獨結合中
                list.addAll(nd.getNewslist());
                return null;
            }

            protected void onPostExecute(NewsData result) {
                // 刷新
                adapter.notifyDataSetChanged();
            };

        }.execute();
    }

    class MyAdapter extends BaseAdapter {

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

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

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

        @Override
        public View getView(int position, View convertView, ViewGroup parent) {
            ViewHolder holder;
            if (convertView == null) {
                convertView = View.inflate(MainActivity.this,
                        R.layout.list_itme, null);
                holder = new ViewHolder();
                holder.tv_title = (TextView) convertView
                        .findViewById(R.id.tv_title);
                holder.tv_desc = (TextView) convertView
                        .findViewById(R.id.tv_desc);
                holder.tv_time = (TextView) convertView
                        .findViewById(R.id.tv_time);
                holder.iv = (ImageView) convertView.findViewById(R.id.iv);
                convertView.setTag(holder);
            } else {
                holder = (ViewHolder) convertView.getTag();
            }
            holder.tv_time.setText(list.get(position).getCtime());
            holder.tv_desc.setText(list.get(position).getDescription());
            holder.tv_title.setText(list.get(position).getTitle());

            ImageLoader.getInstance().displayImage(
                    list.get(position).getPicUrl(), holder.iv);
            return convertView;
        }

    }

    public static class ViewHolder {
        TextView tv_title;
        TextView tv_desc;
        TextView tv_time;
        ImageView iv;
    }
}

MyApp.java:(MyApplication配置實現)

import com.nostra13.universalimageloader.core.DisplayImageOptions;
import com.nostra13.universalimageloader.core.ImageLoader;
import com.nostra13.universalimageloader.core.ImageLoaderConfiguration;
import com.nostra13.universalimageloader.core.display.FadeInBitmapDisplayer;

import android.app.Application;

public class MyApp extends Application {
    @Override
    public void onCreate() {

        DisplayImageOptions options = new DisplayImageOptions.Builder()
                .showImageOnLoading(R.drawable.ic_launcher)
                .displayer(new FadeInBitmapDisplayer(2000)).cacheOnDisk(true)
                .cacheInMemory(true).build();

        ImageLoaderConfiguration configs = new ImageLoaderConfiguration.Builder(
                this).defaultDisplayImageOptions(options).threadPoolSize(5)
                .build();

        ImageLoader.getInstance().init(configs);
        super.onCreate();
    }
}

News.java:

public class News {
    String ctime;
    String description;
    String picUrl;
    String title;
    String url;

    public String getCtime() {
        return ctime;
    }

    public void setCtime(String ctime) {
        this.ctime = ctime;
    }

    public String getDescription() {
        return description;
    }

    public void setDescription(String description) {
        this.description = description;
    }

    public String getPicUrl() {
        return picUrl;
    }

    public void setPicUrl(String picUrl) {
        this.picUrl = picUrl;
    }

    public String getTitle() {
        return title;
    }

    public void setTitle(String title) {
        this.title = title;
    }

    public String getUrl() {
        return url;
    }

    public void setUrl(String url) {
        this.url = url;
    }

    public News(String ctime, String description, String picUrl, String title,
            String url) {
        super();
        this.ctime = ctime;
        this.description = description;
        this.picUrl = picUrl;
        this.title = title;
        this.url = url;
    }

    @Override
    public String toString() {
        return "News [ctime=" + ctime + ", description=" + description
                + ", picUrl=" + picUrl + ", title=" + title + ", url=" + url
                + "]";
    }

}

NewsData.java:

import java.util.ArrayList;
import java.util.List;

public class NewsData {
    String code;
    String msg;
    List<News> newslist = new ArrayList<News>();

    public String getCode() {
        return code;
    }

    public void setCode(String code) {
        this.code = code;
    }

    public String getMsg() {
        return msg;
    }

    public void setMsg(String msg) {
        this.msg = msg;
    }

    public List<News> getNewslist() {
        return newslist;
    }

    public void setNewslist(List<News> newslist) {
        this.newslist = newslist;
    }

    @Override
    public String toString() {
        return "NewsData [code=" + code + ", msg=" + msg + ", newslist="
                + newslist + "]";
    }

}

NetUtils.java:(獲取網絡信息)

import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.Reader;
import java.net.HttpURLConnection;
import java.net.URL;

/**
 * 網絡工具類
 * 
 * @author Administrator
 * 
 */
public class NetUtils {
    /**
     * 通過get請求 獲取字符數據流
     * 
     * @param path
     * @return
     */
    public static Reader getDataByGet(String path) {
        InputStreamReader isr = null;
        try {
            URL url = new URL(path);
            HttpURLConnection conn = (HttpURLConnection) url.openConnection();
            conn.setRequestMethod("GET");
            int code = conn.getResponseCode();
            if (code == 200) {
                InputStream is = conn.getInputStream();
                isr = new InputStreamReader(is);
            }
        } catch (Exception e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        return isr;
    }
}

實現效果
這裏寫圖片描述

這裏寫圖片描述

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章