在android studio中查看模型状态:Kotlin

问题描述

当我昨天尝试使用SaveInstanceState保存我的textview输出同时将方向从纵向模式更改为横向模式时,我正在处理此代码,但这没有用。所以我想到并意识到我可以使用View Model状态来解决这个问题。与SaveInstance State不同,我尝试执行View Model,但是我发现执行和修复错误并不困难,这是主要活动和viewmodel的代码

主要活动科特林

override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

        var count = 10
        val textCount = findViewById<View>(R.id.textView) as TextView
         val buttonred = findViewById<View>(R.id.injury) as Button
         
         val buttoning = findViewById<View>(R.id.revive) as Button


            var viewmodel = viewmodelProvider(this).get(MainActivityviewmodel::class.java)

            buttonred.setonClickListener {
                if (count >= 0) {

                   count--
                    textCount.text = count.toString()
                }

            }
           
            buttoning.setonClickListener {
                if (count <= 10) {
                    count += 2
                    textCount.text = count.toString()
                }
            }
    }
}

viewmodel Kotlin代码(请注意:我刚刚开始研究它,但是我不知道如何解决

class MainActivityviewmodel: viewmodel() {
    var count = 10
    fun medivial()
    {
        count--
    }
}

这是xml文件

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context=".MainActivity">

    <TextView
        android:id="@+id/textView"
        android:layout_width="60dp"
        android:layout_height="78dp"
        android:layout_marginStart="145dp"
        android:layout_marginTop="68dp"
        android:layout_marginEnd="145dp"
        android:textSize="50dp"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />
<Button
        android:id="@+id/injury"
        android:layout_width="106dp"
        android:layout_height="wrap_content"
        android:layout_marginHorizontal="150dp"
        android:text="injury"
         />
<Button
        android:id="@+id/revive"
        android:layout_width="197dp"
        android:layout_height="wrap_content"
        android:layout_marginHorizontal="109dp"
        android:text="revive" />
</LinearLayout>

需要帮助

解决方法

您必须将LiveData添加到ViewModel类并进行观察。您的活动类别不能包含count之类的任何数据。 ViewModel必须执行所有操作,仅向View(MainActivity)提供数据

向您的Gradle(module.app)文件添加:

dependencies {
    def lifecycle_version = "2.2.0"

    // ViewModel
    implementation "androidx.lifecycle:lifecycle-viewmodel-ktx:$lifecycle_version"
    // LiveData
    implementation "androidx.lifecycle:lifecycle-livedata-ktx:$lifecycle_version"
}

MainActivityViewModel类:

import androidx.lifecycle.LiveData
import androidx.lifecycle.MutableLiveData
import androidx.lifecycle.ViewModel


internal class MainActivityViewModel : ViewModel() {

    private val _count: MutableLiveData<Int> = MutableLiveData()
    val count: LiveData<Int>
        get() = _count

    init {
        _count.value = START_VALUE
    }

    fun increment() {
        _count.value = _count.value!! + 1
    }

    fun decrement() {
        _count.value = _count.value!! - 1

    }

    companion object {
        private const val START_VALUE = 10
    }
}

MainActivity类:

import android.os.Bundle
import android.view.View
import android.widget.Button
import android.widget.TextView
import androidx.appcompat.app.AppCompatActivity
import androidx.lifecycle.ViewModelProvider

class MainActivity : AppCompatActivity()
{
    private lateinit var viewModel: MainActivityViewModel

    override fun onCreate(savedInstanceState: Bundle?)
    {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

        val textCount = findViewById<View>(R.id.textView) as TextView
        val butIncrement = findViewById<View>(R.id.injury) as Button
        val butDecrement = findViewById<View>(R.id.vial) as Button

        viewModel = ViewModelProvider(this).get(MainActivityViewModel::class.java)

        viewModel.count.observe(this,{
            textCount.text = it.toString()
        })

        butIncrement.setOnClickListener {
            viewModel.increment()
        }

        butDecrement.setOnClickListener {
            viewModel.decrement()
        }
    }
}