KotlinのViewModelとLiveDataを使ったアーキテクチャ例|初心者向けにやさしく解説
生徒
「Kotlinでアプリの画面が回転してもデータが消えないようにする方法ってありますか?」
先生
「その場合は、ViewModelとLiveDataを使うのが一般的です。これらを使うと、画面のライフサイクルに強くなり、データの保持や更新が簡単になりますよ。」
生徒
「それってどうやって使うんですか?難しそうに聞こえます…」
先生
「大丈夫、初心者でも分かるようにゆっくり丁寧に解説しますね。まずはViewModelとLiveDataの役割から見ていきましょう。」
1. ViewModelとは?
ViewModel(ビューモデル)とは、画面(ActivityやFragment)が回転などで破棄されても、データを保持してくれる役割を持った部品です。
普通の変数や関数は画面が閉じられると消えてしまいますが、ViewModelを使うと、アプリ内でデータを長く扱えるようになります。
たとえば、メモアプリで入力中の文字を保存しておきたいときに便利です。
2. LiveDataとは?
LiveData(ライブデータ)は、データが変更されたことを自動的に画面に通知してくれる仕組みです。たとえば、カウンターの数字が変わったら、自動的に表示も更新されます。
「監視(かんし)」してくれるイメージで、見張っていてデータが変わったら教えてくれるので、画面側では手動で更新する必要がありません。
3. ViewModelとLiveDataを使ったアーキテクチャの全体像
以下のような流れで使います:
- ViewModel:アプリのデータや状態を保持
- LiveData:データの変化を監視して画面に通知
- UI(画面):LiveDataの変化に応じて自動的に表示を更新
これにより、コードが整理されて、読みやすく保守しやすくなります。
4. サンプル:カウントアップするアプリ
画面にボタンを置いて、押すたびに数字を1つずつ増やす例です。データはViewModelで管理し、画面にはLiveDataを通して表示します。
class CounterViewModel : ViewModel() {
private val _count = MutableLiveData(0)
val count: LiveData<Int> = _count
fun increment() {
_count.value = (_count.value ?: 0) + 1
}
}
class MainActivity : AppCompatActivity() {
private lateinit var viewModel: CounterViewModel
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
viewModel = ViewModelProvider(this)[CounterViewModel::class.java]
val textView = findViewById<TextView>(R.id.textView)
val button = findViewById<Button>(R.id.button)
viewModel.count.observe(this) { value ->
textView.text = value.toString()
}
button.setOnClickListener {
viewModel.increment()
}
}
}
5. ライフサイクルに強いとは?
スマホの画面を回転すると、内部的には一度画面が「壊されて」また作り直されています。そのとき、普通の変数だと内容が消えてしまいます。
しかし、ViewModelはこのタイミングでもデータを保持してくれるため、数字が「0」に戻ることなく、続きから表示されます。
6. ViewModelとLiveDataを使うメリット
- 画面回転してもデータが保持される
- データの変化が画面に自動で反映される
- 画面のコードがスッキリする(設計がきれいになる)
アーキテクチャというのは、「アプリの設計方法」のことです。
ViewModelとLiveDataを使うことで、アプリの構成がしっかりし、後からの修正も簡単になります。
Kotlinを基礎からしっかり学びたい人や、 Java経験を活かしてモダンな言語にステップアップしたい人には、 定番の入門書がこちらです。
基礎からわかるKotlinをAmazonで見る※ Amazon広告リンク
7. よくある疑問と補足
Q. ViewModelは複数の画面で共有できますか?
→ ActivityとFragmentの関係で共有できますが、基本はそれぞれに用意します。
Q. LiveDataを使わずにTextViewに直接データをセットするのはダメ?
→ 可能ですが、手動で更新し続ける必要があり、バグの原因になります。
【未経験OK】Kotlinで始めるプログラミング入門|ゼロから「動く喜び」を体験する60分
「プログラミングを始めたい」を形にする。最新言語Kotlinで楽しむ、ものづくりの第一歩。
本講座は、プログラミング経験が全くない方のためのエントリー講座です。「コードを書くってどういうこと?」という基本から、世界中で使われている最新言語Kotlin(コトリン)を使って、実際にプログラムを動かすまでを体験します。難しい理屈よりも、まずは「自分の手で動かす楽しさ」を最短距離で実感していただきます。
具体的な体験内容と環境
【つくるもの】
簡単な言葉を入力すると自動で返答してくれる「対話型ミニプログラム」や、計算を自動化する「便利ツール」をゼロから作成します。黒い画面に自分の書いた文字が表示される瞬間は、最高の感動体験です。
【開発環境】
プロのエンジニアが実際に使っている開発ツールIntelliJ IDEA(インテリジェイ)をインストールします。ボタン一つで日本語化し、初心者でも迷わず操作できる「魔法の設定」を一緒に行います。
この60分で得られる3つの体験
プロと同じ道具を揃えることで、明日から一人でもプログラミングを続けられる環境が整います。
「変数」や「型」といった難しい言葉も、身近な例え話で解説。モヤモヤをゼロにします。
Kotlinは英語に近くて読みやすいのが特徴。自分でコードを読んで、間違いを見つけるコツも伝授します。
※本講座は、パソコン操作が不安な方でも安心して受講いただける完全マンツーマンです。あなたのペースに合わせて、一つずつ丁寧に進めていきます。
Kotlinで始めるプログラミング入門|ゼロから「動く喜び」を体験