LiveData не обновляется при изменении видимости? - PullRequest
0 голосов
/ 14 октября 2019

MainActivity

override fun onCreate(savedInstanceState: Bundle?) {
    super.onCreate(savedInstanceState)
    activityMainBinding = DataBindingUtil.setContentView(this, 
 R.layout.activity_main)
    mainViewModel = ViewModelProviders.of(
        this@MainActivity,
        mainViewModelFactory
    )[MainViewModel::class.java]
    activityMainBinding.viewmodel = mainViewModel
    activityMainBinding.lifecycleOwner =   this

        mainViewModel.fetchBusinessList()
mainViewModel.businessList.observe(this, Observer { items ->
        run {
          mainViewModel.isLoading.value = false
        }
    })

MainViewModel

class MainViewModel(val repository: MainActivityRepo) : ViewModel() {

val isLoading: MutableLiveData<Boolean> = MutableLiveData()
lateinit var businessList: LiveData<List<Content>>

fun fetchBusinessList() {
    isLoading.value = true
    businessList = repository.getBusinessList()
}

Макет

    <androidx.core.widget.ContentLoadingProgressBar
        android:id="@+id/clp_fetching"
        style="@style/Widget.AppCompat.ProgressBar"
        android:layout_width="40dp"
        android:layout_height="40dp"
        android:visibility="@{viewmodel.isLoading?View.VISIBLE:View.GONE}"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

Я пробовал setValue, postValue, а также добавил LifeCycleOwner этоне влияет на видимость ложных.

Ответы [ 2 ]

0 голосов
/ 14 октября 2019

Вы должны вызывать executePendingBindings() вручную всякий раз, когда вы меняете значение isLoading.

. Или вы можете использовать настраиваемый адаптер привязки для достижения этой функции:

@BindingAdapter("mutableVisibility")
fun setMutableVisibility(view: View, visibility: MutableLiveData<Boolean>?) {
    val parentActivity: AppCompatActivity? = view.getParentActivity()
    if (parentActivity != null && visibility != null) {
        visibility.observe(parentActivity, Observer { value -> view.visibility = if(value) View.VISIBLE else View.GONE})
    }
}

затемв вашем макете:

<androidx.core.widget.ContentLoadingProgressBar
        android:id="@+id/clp_fetching"
        style="@style/Widget.AppCompat.ProgressBar"
        android:layout_width="40dp"
        android:layout_height="40dp"
        app:mutableVisibility="@{viewmodel.isLoading}"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />
0 голосов
/ 14 октября 2019

Некоторые наблюдения относительно пользователя ViewModel

Вы пытаетесь обновить свойство в модели представления из действия, которое не следует делать.

Представление модели

class MainViewModel(val repository: MainActivityRepo) : ViewModel() {

val isLoading: MutableLiveData<Boolean> = MutableLiveData()
lateinit var businessList: LiveData<List<Content>>

fun fetchBusinessList() {
    isLoading.value = true
    businessList = repository.getBusinessList()
}

// This is where you the content of the list would be received
fun onListUpdated(contentList : List<Content>){
    businessList.value = contentList;
    isLoading.value = false;
 }

Активность

override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
    activityMainBinding = DataBindingUtil.setContentView(this, 
 R.layout.activity_main)
    mainViewModel = ViewModelProviders.of(
        this@MainActivity,
        mainViewModelFactory
    )[MainViewModel::class.java]
    activityMainBinding.viewmodel = mainViewModel
    activityMainBinding.lifecycleOwner =   this

        mainViewModel.fetchBusinessList()
mainViewModel.businessList.observe(this, Observer { items ->
        // Update UI Here
    })
...