本篇內(nèi)容介紹了“Android中怎么使用RecyclerView滾動(dòng)控件”的有關(guān)知識(shí),在實(shí)際案例的操作過程中,不少人都會(huì)遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
創(chuàng)新互聯(lián)建站主要從事成都網(wǎng)站制作、成都網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計(jì)、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)商州,十多年網(wǎng)站建設(shè)經(jīng)驗(yàn),價(jià)格優(yōu)惠、服務(wù)專業(yè),歡迎來電咨詢建站服務(wù):18980820575RecyclerView的使用比ListView的使用是比較復(fù)雜的,ListView的使用是五個(gè)步驟,而我們的RecyclerView的使用有7個(gè)步驟,分別為:
1.在當(dāng)前項(xiàng)目的build.gradle中的dependencies閉包中加入compile ‘com.android.support.recyclerview-v7:xx.x.x'(x是當(dāng)前新版本)
2.布局加入RecyclerView控件以及創(chuàng)建子項(xiàng)布局和適配器類。
3.創(chuàng)建適配器
4.定義數(shù)據(jù)源
5.通過findViewById找RecylerView列表控件
6.通過setLayoutManager()為RecylerView設(shè)置布局管理器
7.通過setAdapter()設(shè)置適配器**
下面我們就利用代碼或圖片一一的細(xì)說每個(gè)步驟:
**第一步:在當(dāng)前項(xiàng)目的build.gradle中的dependencies閉包中加入compile ‘com.android.support.recyclerview-v7:xx.x.x'(x是當(dāng)前新版本)。
因?yàn)锳ndroid將RecyclerView定義在support庫中,想要使用該控件就必須要添加相應(yīng)的依賴庫才可以的。所以就有了第一步的操作。咱們這里介紹兩種添加庫依賴的方法:**
1.直接在文件中手動(dòng)添加,步驟也是用手動(dòng)添加:
添加完成后記得保存,然后點(diǎn)擊以下Sync Now進(jìn)行同步。 什么?什么?Sync Now不知道在哪里?0.0
2.打開布局文件:
當(dāng)系統(tǒng)添加完的時(shí)候,你會(huì)發(fā)現(xiàn)布局界面還是沒有任何東西,別著急!這時(shí)候你在次在選項(xiàng)欄中拖取RecyclerView控件到布局,你會(huì)發(fā)現(xiàn)出現(xiàn)以下界面,證明添加庫依賴成功,可以使用RecyclerView控件:
相對(duì)第一種方法,第二種方法是比較便捷的,可以不需要手動(dòng)輸入和知道當(dāng)前版本,較少了出錯(cuò)率。
第二步:布局加入RecyclerView控件以及創(chuàng)建子項(xiàng)布局和適配器類。其實(shí)第一步咋們已經(jīng)說過了,直接拖取控件到布局界面就行了。
- 那我們就去布局代碼看看,你會(huì)在布局代碼中發(fā)現(xiàn)如下代碼片段:
小伙伴們,發(fā)現(xiàn)其中的特點(diǎn)沒有?對(duì)的,就是RecyclerView怎么跟咱們的Button、TextView等控件的頭部標(biāo)簽寫法不一樣的?。?strong>那是因?yàn)镽ecyclerView 并不是內(nèi)置在系統(tǒng)SDK當(dāng)中,所以需要把完整的包路徑名android.support.v7.widget.RecyclerView寫出來)。
注:直接拖取是沒有生成ID的,這里需要我們手動(dòng)添加,如果是手動(dòng)添加RecyclerView的小伙伴們記得要把完成包名路徑寫出來。
在布局文件中我們需要?jiǎng)?chuàng)建一個(gè)RecyclerView的子項(xiàng)布局,代碼如下:
實(shí)現(xiàn)的預(yù)覽效果,我們?cè)谶@里讓界面實(shí)現(xiàn)左邊是圖片,右邊是文字:
咱們創(chuàng)建一個(gè)Fruit實(shí)體類,并添加構(gòu)造器和重寫get()方法:
最后創(chuàng)建一個(gè)FruitAdapter適配器的類,讓適配器繼承RecyclerView.Adapter,并將泛型指定為FruitAdapter.ViewHolder。其中,ViewHolder是我們FruitAdapter中定義的一個(gè)內(nèi)部類。并重寫:onCreateViewHolder()、onBindViewHolder()、getItemCount()3個(gè)方法。全部代碼如下:
public class FruitAdapter extends RecyclerView.Adapter{ //定義集合 private List mFruitList; //利用構(gòu)造器傳入數(shù)據(jù) public FruitAdapter(List FruitList) { this.mFruitList = FruitList; } //創(chuàng)建ViewHolder的實(shí)例 // ①onCreateViewHolder()用于創(chuàng)建ViewHolder實(shí)例,并把加載的布局傳入到構(gòu)造函數(shù) @Override public FruitAdapet.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) { //由于ViewHolder構(gòu)造器需要傳入子項(xiàng)布局View對(duì)象,因此需要實(shí)例化子項(xiàng)布局 View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.activity_fruit, parent, false); //創(chuàng)建ViewHolder對(duì)象 ViewHolder viewHolder = new ViewHolder(view); //返回值 return viewHolder; } //②onBindViewHolder()用于對(duì)RecyclerView子項(xiàng)的數(shù)據(jù)進(jìn)行賦值,會(huì)在每個(gè)子項(xiàng)被滾動(dòng)到屏幕內(nèi)的時(shí)候執(zhí)行 @Override public void onBindViewHolder(final FruitAdapet.ViewHolder holder, int position) { //從集合中把水果對(duì)象拿出來 Fruit fruit = mFruitList.get(position); //調(diào)用holder.ImageView對(duì)象設(shè)置圖片 holder.imageView.setImageResource(fruit.getImageId()); //調(diào)用holder.TextView對(duì)象設(shè)置文字 holder.textView.setText(fruit.getName()); } //③getItemCount()用于知道RecyclerView有多少子項(xiàng) @Override public int getItemCount() { return mFruitList.size(); } //創(chuàng)建ViewHolder繼承RecyclerView.ViewHolder class ViewHolder extends RecyclerView.ViewHolder { ImageView imageView; TextView textView; //重寫ViewHolder public ViewHolder(View itemView) { super(itemView); //通過View對(duì)象的findViewById方法獲取到子項(xiàng)布局的控件保存在成員變量當(dāng)中 imageView = (ImageView) itemView.findViewById(R.id.imageView); textView = (TextView) itemView.findViewById(R.id.textView); } } }
3.在MainActivity中定義數(shù)據(jù)源 4定義適配器
5.通過findViewById找RecylerView列表控件
6.通過setLayoutManager()為RecylerView設(shè)置布局管理器
7.創(chuàng)建適配器
8.通過setAdapter()設(shè)置適配器
public class MainActivity extends AppCompatActivity { private ListfruitList; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); //第三步:定義數(shù)據(jù)源,單獨(dú)利用一個(gè)方法 fruitData(); //第四步:創(chuàng)建適配器 FruitAdapet adapet = new FruitAdapet(fruitList); //第五步:找布局控件 RecyclerView recyclerView= (RecyclerView) findViewById(R.id.recyclerView); //第六步:通過setLayoutManager()為RecylerView設(shè)置布局管理器 //設(shè)置為垂直方向 //水平方向的參數(shù)為:(this,LinearLayoutManager.HORIZONTAL, false); LinearLayoutManager linearLayoutManager=new LinearLayoutManager(this, LinearLayoutManager.VERTICAL,false); recyclerView.setLayoutManager(linearLayoutManager); //第七步:設(shè)置適配器 recyclerView.setAdapter(adapet); } public void fruitData() { //創(chuàng)建一個(gè)集合保存數(shù)據(jù) fruitList = new ArrayList<>(); //圖片我就用了幾張,然后讓他循環(huán)變換而已,小伙伴可以自己增加各式的圖片 Fruit apple = new Fruit("蘋果", R.drawable.apple); fruitList.add(apple); Fruit banana = new Fruit("香蕉", R.drawable.banana); fruitList.add(banana); Fruit apple1 = new Fruit("蘋果", R.drawable.apple); fruitList.add(apple); Fruit banana1 = new Fruit("香蕉", R.drawable.banana); fruitList.add(banana); Fruit apple2 = new Fruit("蘋果", R.drawable.apple); fruitList.add(apple); Fruit banana2 = new Fruit("香蕉", R.drawable.banana); fruitList.add(banana); Fruit apple3 = new Fruit("蘋果", R.drawable.apple); fruitList.add(apple); Fruit banana3 = new Fruit("香蕉", R.drawable.banana); fruitList.add(banana); Fruit apple4 = new Fruit("蘋果", R.drawable.apple); fruitList.add(apple); Fruit banana4 = new Fruit("香蕉", R.drawable.banana); fruitList.add(banana); } }
好了,RecyclerView的基本代碼就這這樣的,大家僅供參考。
其實(shí)RecyclerView還有點(diǎn)擊事件的,我這里就沒有寫了。如果后期小伙伴們需要可以添加上去。
其實(shí)這個(gè)也是實(shí)現(xiàn)瀑布流效果的代碼,如果咱們想要實(shí)現(xiàn)瀑布流效果,只需要把子項(xiàng)布局設(shè)置為只顯示圖片(瀑布流需要使用大小不同的圖片才能看出更好的效果),并調(diào)整一下布局參數(shù)就行了的。在布局設(shè)置布局管理中設(shè)置如下代碼:
//第一個(gè)參數(shù)用于指定布局的列數(shù) //第二個(gè)參數(shù)用于指定布局的排列方向 StaggeredGridLayoutManager layoutManager=new StaggeredGridLayoutManager(3,StaggeredGridLayoutManager.VERTICAL); recyclerView.setLayoutManager(layoutManager);
“Android中怎么使用RecyclerView滾動(dòng)控件”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!