iT邦幫忙

2021 iThome 鐵人賽

DAY 18
0
Mobile Development

Android 新手入門學習系列 第 18

Day18 Android - RecyclerView應用

  • 分享至 

  • xImage
  •  

此元件是在Android 5.0提供的元件,相較於ListView,RecyclerView比較有彈性,且可說是ListView的改良版,但同樣都可通過adapter(配置器)來達成我們想要顯示的列表式內容,那麼就開始今天的主題RecyclerView。

布局

首先先在布局中拉入一個recyclerView的元件,並給予她一個id(為了findViewById綁定)。
https://ithelp.ithome.com.tw/upload/images/20210830/20139259diIGbnWTbg.png

    <androidx.recyclerview.widget.RecyclerView
        android:id="@+id/recyclerview"
        android:layout_width="match_parent"
        android:layout_height="160dp"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

高度的部分定義特定範圍會好一點,不然他會一直延伸到這個布局的底邊界。


建立Adapter處理資料

首先new一個java class,然後繼承RecyclerView.Adapter,接著在class旁邊按alt+enter會發現他有三個methods需要實現。
https://ithelp.ithome.com.tw/upload/images/20210912/201392592zzjwP2vdP.png


https://ithelp.ithome.com.tw/upload/images/20210912/20139259cht3rc8A8b.png
那麼接著來提提他分別的功能,等等就來建立ViewHolder並設計,而今天會用到兩筆資料(title、body)。

public class DataAdapter extends RecyclerView.Adapter {
    
    @Override
    public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        return null;//這邊主要用於連接布局檔以生成、return view等操作(目前是空的)
    }

    @Override
    public void onBindViewHolder(RecyclerView.ViewHolder holder, int position) {
        //這邊用於控制元件的顯示及資料等操作
    }

    @Override
    public int getItemCount() {
        return 0;//return多少就有幾筆資料
    }
}

建立ViewHolder

public class DataAdapter extends RecyclerView.Adapter<DataAdapter.MyHolder> {
    //建立ViewHolder,此ViewHolder名為MyHolder
    public class MyHolder extends RecyclerView.ViewHolder{
        public MyHolder(View Holder){
            super(Holder);
            //可取得從onCreateViewHolder的view,此ViewHolder用於綁定主布局元件
        }
    }
    //將原本RecyclerView.ViewHolder的部分皆改為MyHolder
    @Override
    public MyHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        return null;//這邊主要用於連接布局檔以生成、return view等操作(目前是空的)
    }

    @Override
    public void onBindViewHolder(MyHolder holder, int position) {
        //這邊用於控制元件的顯示及資料等操作
    }

    @Override
    public int getItemCount() {
        return 0;//return多少就有幾筆資料
    }
}

接著就來進行設計並定義、處理傳入的資料。


設計

public class DataAdapter extends RecyclerView.Adapter<DataAdapter.MyHolder> {
    ArrayList<String> data1,data2;//宣告資料1(title)、資料2(body)
    public DataAdapter(ArrayList<String> data1,ArrayList<String> data2){
        //取得List內容
        this.data1=data1;
        this.data2=data2;
    }
    //將原本RecyclerView.ViewHolder的部分皆改為MyHolder
    @Override
    public MyHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        View view=LayoutInflater.from(parent.getContext()).inflate(R.layout.addlist,parent,false);
        return new MyHolder(view);//連接布局,新增一個view給viewholder綁定元件
    }

    @Override
    public void onBindViewHolder(MyHolder holder, int position) {
        holder.title.setText(data1.get(position));//position為索引值,用get來取得arraylist資料
        holder.body.setText(data2.get(position));
    }

    @Override
    public int getItemCount() {
        return data1.size();    //回傳List大小
    }
    public class MyHolder extends RecyclerView.ViewHolder{
        private TextView title,body;
        public MyHolder(View Holder){
            super(Holder);
            //取得從onCreateViewHolder的view,此ViewHolder綁定主布局元件
            title=Holder.findViewById(R.id.textView);
            body=Holder.findViewById(R.id.textView2);
        }
    }
}

addlist.xml

我做的比較簡陋一點,這邊是每個list去參照的布局,這邊就不用再擔心說會在螢幕顯示TextView這段字串了,因為已經透過onBindViewHolder這個method來使用setText設定文字了。
https://ithelp.ithome.com.tw/upload/images/20210912/20139259Nt55VptDu1.png


主程式

public class MainActivity extends AppCompatActivity {
    RecyclerView recyclerView;
    DataAdapter dataAdapter;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        recyclerView=findViewById(R.id.recyclerview);//綁定recyclerView元件的ID
        ArrayList<String> titleList = new ArrayList<>();
        ArrayList<String> bodyList = new ArrayList<>();
        for(int i=0;i<20;i++){//.add為新增資料,.get為取得資料(此處新增20筆資料)
            titleList.add("title"+i);
            bodyList.add("body"+i);
        }
        dataAdapter=new DataAdapter(titleList,bodyList);//將資料進行處理
        recyclerView.setLayoutManager(new LinearLayoutManager(this));//使用LinearLayout布局
        //分割線套件
        recyclerView.addItemDecoration(new DividerItemDecoration(this,
                DividerItemDecoration.VERTICAL));
        recyclerView.setAdapter(dataAdapter);//將資料給recyclerView顯示
    }
}

成果

https://ithelp.ithome.com.tw/upload/images/20210912/20139259wsWEecJ2Zv.jpg


https://ithelp.ithome.com.tw/upload/images/20210912/20139259ptRhNLnqsA.jpg


上一篇
Day17 Android - Array、ArrayList、List
下一篇
Day19 Android - NestedScrollView
系列文
Android 新手入門學習30
圖片
  直播研討會
圖片
{{ item.channelVendor }} {{ item.webinarstarted }} |
{{ formatDate(item.duration) }}
直播中

尚未有邦友留言

立即登入留言