viewmodel : Administre datos relacionados con la interfaz de una manera orientada al ciclo de vida para obtener y retener la información necesaria para Actividad / Fragmento
A modo de ejemplo, la siguiente vista principal Modelo de interfaz siguiente, tres controles de interfaz, una fracción superior, dos botones fraccionarios se realizan siguiendo la operación +1 y +3
MainActivity
/**
* 普通mvc写法实现
*/
public class MainActivity extends AppCompatActivity {
private TextView textView;
private Button button1;
private Button button2;
private ScoreModel scoreModel;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(null);
setContentView(R.layout.activity_main);
textView = findViewById(R.id.textView);
button1 = findViewById(R.id.button1);
button2 = findViewById(R.id.button2);
scoreModel = new ScoreModel();
textView.setText(String.valueOf(scoreModel.getScore()));
button1.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
scoreModel.addScore(1);
textView.setText(String.valueOf(scoreModel.getScore()));
}
});
button2.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
scoreModel.addScore(2);
textView.setText(String.valueOf(scoreModel.getScore()));
}
});
}
}
Clase de entidad ScoreModel
/**
* 普通实体类
*/
public class ScoreModel {
private int score = 0;
public int getScore() {
return score;
}
public void addScore(int n) {
this.score += n;
}
}
Archivo de diseño activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout 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"
tools:context=".MainActivity">
<TextView
android:id="@+id/textView"
android:layout_width="wrap_content"
android:layout_height="32dp"
android:text="0"
android:textSize="18sp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_bias="0.21" />
<Button
android:id="@+id/button2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="+2"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.498"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_bias="0.461" />
<Button
android:id="@+id/button1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="+1"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.498"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_bias="0.32" />
</androidx.constraintlayout.widget.ConstraintLayout>
El efecto de ejecución es el siguiente: cuando la
aplicación se cambia a un segundo plano, cuando la memoria está escasa, el teléfono finaliza el proceso para ahorrar energía, el usuario cambia manualmente la configuración del teléfono (como el idioma del teléfono) o la configuración de la aplicación, y luego abre la aplicación, la puntuación calculada previamente en este momento se convierte en 0; El efecto es el siguiente
Anteriormente, la caché de datos de la interfaz se guardaba en el método onSaveInstanceState, y el paquete se evaluaba en el método onRestoreInstanceState o en el método onCreate, y el valor se repitió; con el modelo de vista, es mucho más simple
Agregue la clase MyMainModel para heredar ViewModel y reemplace el ScoreModel en este momento. El código es el siguiente
/**
* ViewModel测试类
*/
public class MainViewModel1 extends ViewModel {
private int score = 0;
public int getScore() {
return score;
}
public void addScore(int n) {
this.score += n;
}
}
Agregar dependencia
implementation 'androidx.lifecycle:lifecycle-extensions:2.0.0'
La MainActivity modificada, otra sin cambios
/**
* ViewModel测试类
*/
public class MainActivity1 extends AppCompatActivity {
private TextView textView;
private Button button1;
private Button button2;
private MainViewModel1 viewModel;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(null);
setContentView(R.layout.activity_main);
textView = findViewById(R.id.textView);
button1 = findViewById(R.id.button1);
button2 = findViewById(R.id.button2);
viewModel = ViewModelProviders.of(this).get(MainViewModel1.class);//新版写法可能不同
textView.setText(String.valueOf(viewModel.getScore()));
button1.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
viewModel.addScore(1);
textView.setText(String.valueOf(viewModel.getScore()));
}
});
button2.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
viewModel.addScore(2);
textView.setText(String.valueOf(viewModel.getScore()));
}
});
}
}
El efecto de operación es el mismo que antes, ahora intente cambiar el idioma del sistema y descubrió que los datos de la interfaz no se perderán, porque viewodel nos ayudó a lidiar con eso
Solo este registro, si tiene alguna pregunta, por favor señale, gracias