[Android] RecyclerView の基本的な設定

cat64 01 - [Android] RecyclerView の基本的な設定

RecyclerView は、ListView をさらに進化させて柔軟にしたものだそうです。
cellをドラッグ&ドロップさせたり追加・消去などに強みを発揮するようですが、ここでは簡単な基本設定を試してみます。
 

Android Studio 3.5.3
API 29



RecyclerView

 
わかりやすい説明がGoogle Developerのリストとカードの作成にあります。最初にこのサンプルコードを元にして実際に動かしてみたいと思います。
 
RecyclerView - [Android] RecyclerView の基本的な設定
Ref: 図 1 RecyclerView ウィジェット
 
基本的にはListViewの進化形なので、ListViewがわかっていると理解しやすいです。
 
LayoutManagerはアイテムの位置調整を行い、 ビューの再利用(Recycle)する機能をもっているそうですが、ListViewでもconvertViewを駆使すればできていた事でしたが、あえて記述しなくても良くなったということでしょう。

device 2016 12 17 110210 170x300 - [Android] RecyclerView の基本的な設定
 

 

シンプルなサンプルコード

 
最初にRecyclerViewのライブラリーをbuild.gradleに追加しないといけません
旧:com.android.support:recyclerview-v7:x.x.x
AndroidX:androidx.recyclerview:recyclerview:x.x.x
このバージョンはビルドツールのバージョンと合っていないとエラーになることもありますので、それぞれの環境で調整してください。
使っている環境に合わせる必要があります(つまり簡単にコピペするだけだとハマります)
 
build.gradle

 
以下、リストとカードの作成にあるサンプルコードを元に簡単なサンプルを作っててみます。
レイアウトのコードをLinearLayoutに入れました。
activity_main.xml

 
RecyclerView オブジェクトのハンドルを取得してレイアウト マネージャーに接続し、アダプターにデータセットを渡します。
データセットとして20個の要素を持つ配列で設定してみます。

MainActivity.java

 
Adapterですが、別ファイルとして作成しました。
MyAdapter.java

 
cellとなる部分はListViewと同じように要素のレイアウトで作ります
my_text_view.xml

 
ここで注意するところは、layout_heightを限定しないとセルの高さがとんでもなく広がってしまうことがあります。
 
これでリストがスクロールするRecyclerViewの簡単な例ができたと思います。
 
recyclerview 02 - [Android] RecyclerView の基本的な設定
 
しかし、これは境界ラインも無いしカスタマイズで作り込む必要があります。
逆にいうとListViewのカスタマイズには限界があったところを柔軟に拡張したということでしょうか。

 

画像とテキストのサンプルコード

 
いままでの例を元に、画像と文字列を組み合わせた構成されるcellを作ってみたいと思います。
また、データセットも追加・削除・移動を前提にするためArrayListを使います。
また双方向連結リストのLinkedListを使用すれば削除・追加などが早くなるようです。

120x120pix程度の画像を10枚用意してdrawable-v24に入れます。

recyclerview 03 - [Android] RecyclerView の基本的な設定
 
バージョンなどは自分の環境に合わせてください
build.gradle

 

MainActivity.java

 
MyAdapter.java

 
activity_main.xml

 
cellのレイアウトは色々と設定しました
my_text_view.xml

 
strings.xml

 

サンプル動画

 
少しはましになったでしょうか
 

 
 
関連ページ:

 
Reference:
リストとカードの作成 | Android Developers
RecyclerView | Android Developers

誤字脱字、意味不明で分からにゃイ、
などのご意見はこちらから mailフォーム

ブックマークしておくと便利です このエントリーをはてなブックマークに追加

 

アプリ開発が上達するお勧め

アプリ開発を始めたけどわからないところがあり、誰かに聞きたいけど周りにはそんな人はいない…あるいは、会社で働いていて日中そんなに時間をとれないなど、オンラインのプログラミングスクールがいいでしょう。

オンラインスクールは色々ありますが、以下の3つはAndroidが学習できる老舗スクールです。


TECH ACADEMY
Androidアプリコース


こういうものではアプリ作れないと言う意見もありますが、それは結局本人のやる気があるかないかです。やる気があっても独学では突破しにくいところは教えてもらうのが一番早い。


侍エンジニア塾
侍エンジニア塾 無料体験レッスン


とても簡単なことなのに本やネットの画像だけでは分かりにくいことはあります。実際に質問してピンポイントで教えてもらうと、なんだそんなこと、と言うのがけっこうあります。


CodeCamp
~約8,000名の受講生と80社以上の導入実績~
現役エンジニアのオンライン家庭教師CodeCamp




直接(ネットで)誰か分かる人に聞いた方が早く解決して、上達も早いと思います。


無料で転職まで
これはアプリ限定ではありませんが無料です
その代わり就職することを前提にしたスクールでエンジニアになって職を得たいのであれば手っ取り早いかもしれません




シェアする

  • このエントリーをはてなブックマークに追加

フォローする