问题描述
当我昨天尝试使用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()
}
}
}