Android pulltorefresh使用

来源:http://www.cnblogs.com/hyyweb/archive/2016/02/26/5220834.html
-Advertisement-
Play Games

pulltorefresh插件可以輕鬆實現上拉下拉刷新,github.com上直接搜索進行下載。 佈局文件: <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:ptr="http://sc


pulltorefresh插件可以輕鬆實現上拉下拉刷新,github.com上直接搜索進行下載。

佈局文件:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:ptr="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context=".MainActivity" >


    <com.handmark.pulltorefresh.library.PullToRefreshListView
    android:id="@+id/pull_to_refresh_listview"
    android:layout_height="fill_parent"
    android:layout_width="fill_parent"
    ptr:ptrDrawable="@drawable/default_ptr_flip"
    ptr:ptrAnimationStyle="flip"
    ptr:ptrHeaderBackground="@android:color/transparent"
    ptr:ptrHeaderTextColor="#919191"
     />
</RelativeLayout>

核心代碼如下,這裡用到了Android當中不少的知識點,其中主要的是非同步任務處理、自定義適配器。

package com.example.pulltorefresh;

import java.util.ArrayList;

import com.handmark.pulltorefresh.library.ILoadingLayout;
import com.handmark.pulltorefresh.library.PullToRefreshBase;
import com.handmark.pulltorefresh.library.PullToRefreshListView;

import android.os.AsyncTask;
import android.os.Bundle;
import android.app.Activity;
import android.content.Context;
import android.view.LayoutInflater;
import android.view.Menu;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.TextView;

public class MainActivity extends Activity {

    private PullToRefreshListView pullToRefreshView;
    private ArrayList<Music> musics=new ArrayList<Music>();
    private DataAdapter dataAdapter;
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        
        pullToRefreshView = (PullToRefreshListView) findViewById(R.id.pull_to_refresh_listview);
        pullToRefreshView.setOnRefreshListener(new PullToRefreshBase.OnRefreshListener2() {

            @Override
            public void onPullDownToRefresh(PullToRefreshBase refreshView) {
                // TODO 自動生成的方法存根
                new DataAsyncTask(MainActivity.this).execute();
            }

            @Override
            public void onPullUpToRefresh(PullToRefreshBase refreshView) {
                // TODO 自動生成的方法存根
                new DataAsyncTask(MainActivity.this).execute();
            }
        });
        pullToRefreshView.setMode(PullToRefreshBase.Mode.BOTH);
        ILoadingLayout startLabels = pullToRefreshView    
                .getLoadingLayoutProxy(true, false);    
        startLabels.setPullLabel("下拉刷新...");// 剛下拉時,顯示的提示    
        startLabels.setRefreshingLabel("正在載入...");// 刷新時    
        startLabels.setReleaseLabel("放開刷新...");// 下來達到一定距離時,顯示的提示    
    
        ILoadingLayout endLabels = pullToRefreshView.getLoadingLayoutProxy(    
                false, true);    
        endLabels.setPullLabel("上拉刷新...");// 剛下拉時,顯示的提示    
        endLabels.setRefreshingLabel("正在載入...");// 刷新時    
        endLabels.setReleaseLabel("放開刷新...");// 下來達到一定距離時,顯示的提示    
        loadData();
        dataAdapter=new DataAdapter(this, musics);
        pullToRefreshView.setAdapter(dataAdapter);
    }


    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.main, menu);
        return true;
    }
    
    private int count;
    private void loadData(){
        for(int i=0;i<10;i++){
            musics.add(new Music("歌曲-"+count,"歌手-"+count));
            count++;
        }
    }
    static class DataAsyncTask extends AsyncTask<Void, Void, String>{
        private MainActivity mainActivity;
        public DataAsyncTask(MainActivity mainActivity){
            this.mainActivity=mainActivity;
        }

        @Override
        protected String doInBackground(Void... arg0) {
            try {
                Thread.sleep(2000);
            } catch (InterruptedException e) {
                // TODO 自動生成的 catch 塊
                e.printStackTrace();
            }
            mainActivity.loadData();
            return "success";
        }
        
        @Override
        protected void onPostExecute(String result) {
            // TODO 自動生成的方法存根
            super.onPostExecute(result);
            if("success".equals(result)){
                mainActivity.dataAdapter.notifyDataSetChanged();
                mainActivity.pullToRefreshView.onRefreshComplete();
                
            }
        }
    }
    
    static class DataAdapter extends BaseAdapter{

        private Context ctx;
        private ArrayList<Music> musics;
        public DataAdapter(Context ctx,ArrayList<Music> musics){
            this.ctx=ctx;
            this.musics=musics;
        }
        @Override
        public int getCount() {
            // TODO 自動生成的方法存根
            return musics.size();
        }

        @Override
        public Object getItem(int arg0) {
            // TODO 自動生成的方法存根
            return musics.get(arg0);
        }

        @Override
        public long getItemId(int arg0) {
            // TODO 自動生成的方法存根
            return arg0;
        }

        //ViewHolder就是一個持有者的類,他裡面一般沒有方法,只有屬性,作用就是一個臨時的儲存器,
        //把你getView方法中每次返回的View存起來,可以下次再用。這樣做的好處就是不必每次都到佈局文件中去拿到你的View,提高了效率
        @Override
        public View getView(int arg0, View arg1, ViewGroup arg2) {
            ViewHolder vh;
            if(arg1==null){
                arg1=LayoutInflater.from(ctx).inflate(R.layout.listitem,null);
                vh=new ViewHolder();
                vh.tv_title=(TextView) arg1.findViewById(R.id.gequ);
                vh.tv_singer=(TextView) arg1.findViewById(R.id.geshou);
                arg1.setTag(vh);
            }
            vh=(ViewHolder) arg1.getTag();
            Music m=musics.get(arg0);
            vh.tv_title.setText(m.getTitle());
            vh.tv_singer.setText(m.getSinger());
            return arg1;
        }
        
        static class ViewHolder{
            TextView tv_title;
            TextView tv_singer;
        }
    }
}

附帶核心代碼中用到的Music類,自定義適配器用到的自定義佈局很簡單,就兩個TextView,這裡略。

package com.example.pulltorefresh;

public class Music {
    private String title;
    private String singer;
    public String getTitle() {
        return title;
    }
    public void setTitle(String title) {
        this.title = title;
    }
    public String getSinger() {
        return singer;
    }
    public void setSinger(String singer) {
        this.singer = singer;
    }
    public Music(String title, String singer) {
        this.title = title;
        this.singer = singer;
    }
    public Music() {
    }
    
}

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • ReactNative高級交流群 127482131 或訪問 http://blog.1ygowu.com ReactNative技術專題
  • 1、自定義ViewGroup 1 /** 2 * Created by Administrator on 2016/2/26. 3 * 4 * --------自動換行的ViewGroup----------- 5 */ 6 public class LineWrapLayout extends V
  • 單例模式 單例模式幾乎是設計模式中最簡單的形式了。在使用單例時,單例對象的類必須保證只有一個勢力存在。許多時候整個系統只需要擁有一個全局對象。保證一個類僅有一個實例,並提供一個訪問它的全局訪問點。經常用於設計約束或者為了控制對有限資源的訪問。 單例模式的實現思路:一個類只能創建一個實例(永遠是同一個
  • 開源中國android端版本號:2.4 啟動界面: 在AndroidManifest.xml中找到程式的入口, 屏幕方向設置為豎屏,主題為AppStartLoad,關於它的定義如下: welcome.png就是啟動頁顯示的圖片,填充了整個屏幕。 AppS...
  • 1 在ViewPager的適配器中的getCount()長度設置無限大Integer.MAX_VALUE 2 明白當前currentIten 為position % images.length; 3 設置一開始ViewPager的位置 viewPager.setCurrentItem((images
  • 學習筆記 compileDebugJavaWithJavac,缺少插件,在module app gradle文件最上面添加一段 apply plugin: 'me.tatarka.retrolambda'(插件根據需要添加,此處為支持lambda表達式的插件)添加好以後還得在priject app
  • Print Description of "string":把 string 的信息輸出到控制台。Copy:複製 string 的信息,包含變數名,類名和值。View Value As:以什麼類型的格式來查看變數,預設情況下會自動推斷類型。Edit Value:可以直接修改變數的值。在 Swift中
  • 前情提要:我的測試機是華為榮耀6,我裝過一個16G的記憶體卡 因為要面試的需要,我的一個演示項目用的是android本地的WebService。然而寫好的webService部署到本地上,應用怎麼獲取數據都報錯了,只有幾個返回的僅僅是字元串的沒有問題。查看了代碼,正常的部分都是直接返回字元串的。不正常
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...