Я делаю маленькое Tasker для Android с kotlin и местом для хранения. Я разделил основное действие на несколько фрагментов, а затем создал ViewModel для каждого. Теперь в процессе инициализации мне нужна моя программа, чтобы проанализировать все задачи из базы данных, а затем создать несколько радиокнопок в ListFragment
. Наблюдатель работает довольно хорошо, но переменная List<Task>
всегда поставляется с пустым списком ... Наблюдатель работает хорошо, потому что Log.i("ListFragment", "List is empty!")
существует. Так в чем же проблема?
Вот код:
class ListFragment : Fragment() {
override fun onCreateView(
inflater: LayoutInflater, container: ViewGroup?,
savedInstanceState: Bundle?): View? {
val binding: FragmentListBinding = DataBindingUtil.inflate(
inflater, R.layout.fragment_list, container, false)
val application = requireNotNull(this.activity).application
val dataSource = TaskDatabase.getInstance(application).taskDatabaseDao
val viewModelFactory = ListViewModelFactory(dataSource, application)
val listViewModel =
ViewModelProviders.of(this, viewModelFactory).get(ListViewModel::class.java)
binding.listViewModel = listViewModel
binding.setLifecycleOwner(this)
binding.addButton.setOnClickListener {
findNavController().navigate(R.id.action_listFragment_to_createTaskFragment)
}
listViewModel.tasks.observe(this, Observer {
Log.i("ListFragment", "List is empty!")
it?.forEach {
Log.i("ListFragment", "tasks exist")
val radioButton = RadioButton(context)
radioButton.text = it.title
radioButton.visibility = View.VISIBLE
radioButton.setOnClickListener {
Toast.makeText(context, "Working", Toast.LENGTH_SHORT).show()
}
}
})
return binding.root
}
}
class ListViewModel(
val database: TaskDao,
application: Application) : AndroidViewModel(application) {
private val viewModelJob = Job()
private val uiScope = CoroutineScope(Dispatchers.Main + viewModelJob)
private val _tasks = MutableLiveData<List<Task>>()
val tasks: LiveData<List<Task>>
get() = _tasks
init {
initializeTasks()
}
private fun initializeTasks() {
uiScope.launch {
_tasks.value = getTasksFromDatabase()?.value
Log.i("ListViewModel", "something")
}
}
private suspend fun getTasksFromDatabase(): LiveData<List<Task>>? {
return withContext(Dispatchers.IO) {
database.getAllTasks()
}
}
override fun onCleared() {
super.onCleared()
viewModelJob.cancel()
}
}
Заранее спасибо за помощь!