为了实现跨 Activity
的 ViewModel
数据共享,你可以使用一个不同的方法,比如使用 ViewModelProvider
与 Activity
范围的 ViewModel
配合 LiveData
进行数据传递,或者更简单地使用 SharedPreferences
、Intent
或 Application
级别的单例模式来共享数据。
不过,另一种常用的方式是通过 Singleton
模式和 Application
级别的 LiveData
或其他全局存储器来共享数据。
解决方法:使用 Singleton
模式进行数据共享
通过 Singleton
模式在应用程序范围内创建一个 SharedViewModel
或者一个全局的 LiveData
,这样可以在应用程序的多个 Activity
之间共享数据。
1. 创建 DataRepository
类
我们可以通过一个 Singleton
类来保存和共享数据,这个类将作为全局数据存储器。
package com.example.gamecontrol;import androidx.lifecycle.LiveData;
import androidx.lifecycle.MutableLiveData;public class DataRepository {private static DataRepository instance;private final MutableLiveData<Float> angleLiveData = new MutableLiveData<>();private DataRepository() {}public static synchronized DataRepository getInstance() {if (instance == null) {instance = new DataRepository();}return instance;}public LiveData<Float> getAngleLiveData() {return angleLiveData;}public void setAngle(float angle) {angleLiveData.setValue(angle);}
}
2. 修改 MainActivity
以使用 DataRepository
在 MainActivity
中,通过 DataRepository
来设置和获取方向盘角度数据。
package com.example.gamecontrol;import android.content.Intent;
import android.os.Bundle;
import android.widget.Button;
import android.widget.TextView;import androidx.appcompat.app.AppCompatActivity;public class MainActivity extends AppCompatActivity {private SteeringWheelView steeringWheelView;private TextView angleTextView;private Button navigateButton;private DataRepository dataRepository;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);steeringWheelView = findViewById(R.id.steeringWheelView);angleTextView = findViewById(R.id.angleTextView);navigateButton = findViewById(R.id.navigateButton);// 获取 DataRepository 的实例dataRepository = DataRepository.getInstance();// 观察方向盘角度变化steeringWheelView.getAngleLiveData().observe(this, angle -> {// 更新角度显示angleTextView.setText("Angle: " + angle + "°");dataRepository.setAngle(angle); // 更新全局 DataRepository 中的角度数据});// 设置按钮点击事件,启动 SecondActivitynavigateButton.setOnClickListener(v -> {Intent intent = new Intent(MainActivity.this, SecondActivity.class);startActivity(intent);});}
}
3. 修改 SecondActivity
以使用 DataRepository
在 SecondActivity
中,通过 DataRepository
来观察和获取方向盘的角度数据。
package com.example.gamecontrol;import android.os.Bundle;
import android.widget.TextView;import androidx.appcompat.app.AppCompatActivity;public class SecondActivity extends AppCompatActivity {private TextView angleTextView;private DataRepository dataRepository;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_second);angleTextView = findViewById(R.id.angleTextView);// 获取 DataRepository 的实例dataRepository = DataRepository.getInstance();// 观察全局的角度数据变化dataRepository.getAngleLiveData().observe(this, angle -> {// 更新角度显示angleTextView.setText("Angle from MainActivity: " + angle + "°");});}
}
总结
通过 Singleton
模式的 DataRepository
类,你可以确保在整个应用程序的生命周期内共享数据,并且这些数据在任何 Activity
中都可以访问和更新。这种方法可以避免 Application
转换为 ViewModelStoreOwner
的问题,同时实现了跨 Activity
的数据共享。
相关文章:
链接: Android实现自定义方向盘
链接: Android实现自定义方向盘-2添加陀螺仪
链接: Android实现自定义方向盘-3添加平滑处理
链接: Android实现自定义方向盘-4解决触摸时指针跳跃的问题
链接: Android实现自定义方向盘-5livedata实现
链接: Android实现自定义方向盘-6mvvm传递数据
链接: Android实现自定义方向盘-7livedata,viewmodel相关问题