KotlinのAPI通信をRecyclerViewに連携する方法をやさしく解説!初心者向けサンプル付き
生徒
「KotlinでAPI通信して、画面に一覧表示させたいんですが、どうやってやればいいんですか?」
先生
「一覧表示ならRecyclerViewを使うのが一般的です。APIからデータを取得して、その結果をリスト形式で表示させることができますよ。」
生徒
「APIとRecyclerViewってどうやってつなぐんですか?なんだか難しそうです…」
先生
「大丈夫!今回は初心者でもわかるように、KotlinのAPI通信とRecyclerViewの連携方法をステップごとに説明していきますね。」
1. RecyclerViewとは?API通信とどう関係するの?
RecyclerView(リサイクラービュー)とは、Androidアプリでたくさんのデータをリスト表示するときに使う便利な部品です。
API通信を使うことで、外部からデータを取得して、それをRecyclerViewに表示することができます。例えば、天気情報一覧やニュース記事一覧を表示するときにぴったりです。
2. 必要なライブラリの準備
今回は、HTTP通信ライブラリのRetrofitと、リスト表示のためのRecyclerViewを使います。まずはbuild.gradleに以下の依存関係を追加しましょう。
implementation("com.squareup.retrofit2:retrofit:2.9.0")
implementation("com.squareup.retrofit2:converter-gson:2.9.0")
implementation("androidx.recyclerview:recyclerview:1.2.1")
3. データモデルを定義しよう
APIから受け取るデータの形をKotlinのクラスで表現します。例えば、ユーザー一覧を表示する場合は以下のようなUserデータクラスを作ります。
data class User(
val id: Int,
val name: String,
val email: String
)
4. RetrofitでAPI通信の設定
Retrofitを使って、APIとやりとりするインターフェースを定義します。ここではJSON形式でデータを取得するAPIを想定します。
interface ApiService {
@GET("users")
suspend fun getUsers(): List<User>
}
Retrofitの本体を作成します。
val retrofit = Retrofit.Builder()
.baseUrl("https://example.com/api/")
.addConverterFactory(GsonConverterFactory.create())
.build()
val api = retrofit.create(ApiService::class.java)
5. RecyclerViewのAdapterを作成する
RecyclerViewに表示するためのAdapter(アダプター)を作ります。これは、データをどのように表示するかを定義する部分です。
class UserAdapter(private val users: List<User>) : RecyclerView.Adapter<UserAdapter.ViewHolder>() {
class ViewHolder(itemView: View) : RecyclerView.ViewHolder(itemView) {
val nameText = itemView.findViewById<TextView>(R.id.nameText)
val emailText = itemView.findViewById<TextView>(R.id.emailText)
}
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder {
val view = LayoutInflater.from(parent.context).inflate(R.layout.item_user, parent, false)
return ViewHolder(view)
}
override fun onBindViewHolder(holder: ViewHolder, position: Int) {
val user = users[position]
holder.nameText.text = user.name
holder.emailText.text = user.email
}
override fun getItemCount(): Int = users.size
}
6. XMLレイアウトの設定
ユーザー1件分の表示レイアウトをitem_user.xmlとして作成します。
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical"
android:padding="16dp">
<TextView
android:id="@+id/nameText"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="名前" />
<TextView
android:id="@+id/emailText"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="メールアドレス" />
</LinearLayout>
7. Activityで連携処理を実装しよう
ここでいよいよAPI通信とRecyclerViewを連携させます。データ取得後、RecyclerViewに表示する流れです。
class MainActivity : AppCompatActivity() {
private lateinit var recyclerView: RecyclerView
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
recyclerView = findViewById(R.id.recyclerView)
recyclerView.layoutManager = LinearLayoutManager(this)
lifecycleScope.launch {
try {
val users = api.getUsers()
recyclerView.adapter = UserAdapter(users)
} catch (e: Exception) {
e.printStackTrace()
}
}
}
}
Kotlinを基礎からしっかり学びたい人や、 Java経験を活かしてモダンな言語にステップアップしたい人には、 定番の入門書がこちらです。
基礎からわかるKotlinをAmazonで見る※ Amazon広告リンク
8. 実行して確認しよう
アプリを起動すると、APIから取得したデータが一覧として表示されます。RecyclerViewとAPI通信の連携が成功している状態です。
このように、KotlinではRetrofitとRecyclerViewを組み合わせることで、外部から取得したデータを画面上に簡単に表示できます。
【未経験OK】Kotlinで始めるプログラミング入門|ゼロから「動く喜び」を体験する60分
「プログラミングを始めたい」を形にする。最新言語Kotlinで楽しむ、ものづくりの第一歩。
本講座は、プログラミング経験が全くない方のためのエントリー講座です。「コードを書くってどういうこと?」という基本から、世界中で使われている最新言語Kotlin(コトリン)を使って、実際にプログラムを動かすまでを体験します。難しい理屈よりも、まずは「自分の手で動かす楽しさ」を最短距離で実感していただきます。
具体的な体験内容と環境
【つくるもの】
簡単な言葉を入力すると自動で返答してくれる「対話型ミニプログラム」や、計算を自動化する「便利ツール」をゼロから作成します。黒い画面に自分の書いた文字が表示される瞬間は、最高の感動体験です。
【開発環境】
プロのエンジニアが実際に使っている開発ツールIntelliJ IDEA(インテリジェイ)をインストールします。ボタン一つで日本語化し、初心者でも迷わず操作できる「魔法の設定」を一緒に行います。
この60分で得られる3つの体験
プロと同じ道具を揃えることで、明日から一人でもプログラミングを続けられる環境が整います。
「変数」や「型」といった難しい言葉も、身近な例え話で解説。モヤモヤをゼロにします。
Kotlinは英語に近くて読みやすいのが特徴。自分でコードを読んで、間違いを見つけるコツも伝授します。
※本講座は、パソコン操作が不安な方でも安心して受講いただける完全マンツーマンです。あなたのペースに合わせて、一つずつ丁寧に進めていきます。
Kotlinで始めるプログラミング入門|ゼロから「動く喜び」を体験