Android -- RecyclerView的使用

來源:互聯網
上載者:User

Android -- RecyclerView的使用

說明:

RecyclerViewsupport-v7包中的新組件,你可以使用該組件替代ListViewCridView,從命名可以看出RecyclerView會自動回收Item,它並不關心Item的樣式,Item的資料。

那麼要使用RecyclerView要做哪些準備工作呢?

1、既然RecyclerView是support-v7包中的組件,那麼我們的SDK上肯定要下載有support-v7這個包,我們開啟sdkextrasandroidsupport7目錄可以發現有一個recyclerview這個檔案夾,

沒錯這就是我們今天要使用的RecyclerView。

2、我們在build.gradle檔案中添加:

dependencies {    compile fileTree(dir: 'libs', include:['*.jar'])    compile 'com.android.support:appcompat-v7:22.2.1'    compile 'com.android.support:recyclerview-v7:22.2.1'}

PS:Eclipse使用者可以匯入RecyclerView這個project,然後將自己的project依賴於RecyclerView這個project

到這裡我們的準備工作就做完了,接下來就開始編代碼了。

在布局檔案中添加:

對,沒錯這樣我們就往布局中添加了一個RecyclerView控制項

Activity代碼:

import android.os.Bundle;import android.support.v7.app.AppCompatActivity;import android.support.v7.widget.GridLayoutManager;import android.support.v7.widget.LinearLayoutManager;import android.support.v7.widget.RecyclerView;import android.support.v7.widget.StaggeredGridLayoutManager;import java.util.ArrayList;import java.util.HashMap;import java.util.List;import java.util.Map;public class MainActivity extends AppCompatActivity {    private RecyclerView mRecyclerView;    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);        mRecyclerView = (RecyclerView)findViewById(R.id.recyclerView);        //線性布局管理器        LinearLayoutManager llmh = new LinearLayoutManager(this);        //設定為橫向        llmh.setOrientation(LinearLayoutManager.HORIZONTAL);        //線性布局管理器        LinearLayoutManager llmv = new LinearLayoutManager(this);        //設定為縱向        llmv.setOrientation(LinearLayoutManager.VERTICAL);        // 網格布局管理器,第二參數為指定幾列        GridLayoutManager glm = new GridLayoutManager(this, 3);        //流式布局管理器,第一個參數為設定為幾列,第二個參數為相片順序        StaggeredGridLayoutManager sglm =                new StaggeredGridLayoutManager(3,StaggeredGridLayoutManager.VERTICAL);        //設定RecyclerView的布局管理器        mRecyclerView.setLayoutManager(sglm);        //設定資料來源        List> data = new ArrayList>();        int loop = 10;        while (loop>0){            Map map = new HashMap();            map.put(text,I'm data +loop+ ! );            data.add(map);            loop--;        }        RecycleAdapter adapter = new RecycleAdapter(data,this);        //添加適配器        mRecyclerView.setAdapter(adapter);    }}

RecycleAdapter代碼:

import android.support.v7.widget.RecyclerView;import android.view.LayoutInflater;import android.view.View;import android.view.ViewGroup;import android.widget.TextView;import java.util.List;import java.util.Map;public class RecycleAdapter extends RecyclerView.Adapter{    private List> mData;    public RecycleAdapter(List> data){        this.mData = data;    }    class ViewHolder extends RecyclerView.ViewHolder{        private TextView tv;        public ViewHolder(View v){            super(v);            this.tv = (TextView)v.findViewById(R.id.tv);        }    }    @Override    public int getItemCount() {        return mData.size();    }    //填充資料    @Override    public void onBindViewHolder(ViewHolder holder, int position) {        holder.tv.setText(mData.get(position).get(text)+);        holder.tv.setTag(mData.get(position).get(text)+);        //設定監聽事件        holder.tv.setOnClickListener(new View.OnClickListener() {            @Override            public void onClick(View view) {                Toast.makeText(mContext,view.getTag()+,Toast.LENGTH_SHORT).show();            }        });    }    //建立ViewHolder    @Override    public ViewHolder onCreateViewHolder(ViewGroup parent, int position) {        LayoutInflater inflater = LayoutInflater.from(parent.getContext());        View v = inflater.inflate(R.layout.item_layout, parent, false);        ViewHolder vh = new ViewHolder(v);        return vh;    }}

item_layout.xml:

    

到此為止,代碼編寫完畢,以下是:

 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.