亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

功能強(qiáng)大的Android滾動(dòng)控件RecyclerView

 更新時(shí)間:2017年08月29日 16:49:26   作者:wen0801  
這篇文章主要為大家詳細(xì)介紹了功能強(qiáng)大的Android滾動(dòng)控件RecyclerView,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

RecyclerView的使用比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庫(kù)中,想要使用該控件就必須要添加相應(yīng)的依賴庫(kù)才可以的。所以就有了第一步的操作。咱們這里介紹兩種添加庫(kù)依賴的方法:**

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)以下界面,證明添加庫(kù)依賴成功,可以使用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)簽寫法不一樣的啊?那是因?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<FruitAdapter.ViewHolder> {
   //定義集合
  private List<Fruit> mFruitList;

  //利用構(gòu)造器傳入數(shù)據(jù)
  public FruitAdapter(List<Fruit> 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);
    }
  }
}

以上就是適配器FruitAdapter的代碼,代碼都有注釋,相信小伙伴們都可以理解的!

最后的步驟都是在MainActivity中編寫的,咱們這里就不分開一一解釋了,直接貼上代碼,這樣更能一目了然,每個(gè)代碼都有注釋,相信不難理解:

3.在MainActivity中定義數(shù)據(jù)源 4定義適配器
5.通過findViewById找RecylerView列表控件
6.通過setLayoutManager()為RecylerView設(shè)置布局管理器
7.創(chuàng)建適配器
8.通過setAdapter()設(shè)置適配器

public class MainActivity extends AppCompatActivity {
  private List<Fruit> fruitList;
  @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);

對(duì)了運(yùn)行的效果如下,可以實(shí)現(xiàn)上下滾動(dòng):

這里寫圖片描述

謝謝大家閱讀,本文僅供參考,有疑問或錯(cuò)誤請(qǐng)大家指出,謝謝。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論