Как снова отключить настройку модели вида при навигации по фрагменту - PullRequest
0 голосов
/ 04 февраля 2019

Я использую Android Jetpack Navigation, MVVM и привязку данных и столкнулся с одной проблемой.Каждый раз, когда я возвращаюсь назад из фрагмента сведений, мой основной фрагмент списка обновляется (снова вызывается API, и снова рисуется recyclerList).Как я могу предотвратить это?

Это код фрагмента основного списка:

class PostListFragment : BaseFragment() {

private lateinit var viewModel: PostListViewModel

override fun onCreateView(
    inflater: LayoutInflater, container: ViewGroup?,
    savedInstanceState: Bundle?
): View? {

    val binding = TestFragmentBinding.inflate(inflater, container, false)
    val factory = InjectorUtils.providePostListViewModelFactory()
    viewModel = ViewModelProviders.of(this, factory).get(PostListViewModel::class.java)

    val adapter = MainListAdapter()
    binding.mainList.adapter = adapter

    binding.let {
        it.viewmodel = viewModel
        it.setLifecycleOwner(this@PostListFragment)
    }

    subscribeUi(adapter)
    return binding.root
}

private fun subscribeUi(adapter: MainListAdapter) {

    viewModel.progressVisible.postValue(true)
    addToDisposable(viewModel.getContentRepository().getAllPosts(requireContext())
        .subscribeOn(Schedulers.io())
        .observeOn(AndroidSchedulers.mainThread())
        .subscribe({ result ->
            viewModel.progressVisible.postValue(false)
            adapter.submitList(result)
        }, { error ->
            viewModel.progressVisible.postValue(false)
        }))
}

}

Также я должен добавить, что я использую этот фрагмент на MainFragment, которыйсодержит viewPager.

Код моего основного фрагмента:

class MainFragment : Fragment() {

private lateinit var sharedViewModel: SharedNewPostViewModel
private lateinit var viewModel: MainViewModel

override fun onCreateView(
    inflater: LayoutInflater, container: ViewGroup?,
    savedInstanceState: Bundle?
): View? {

    val binding = MainFragmentBinding.inflate(inflater, container, false)

    val factory = InjectorUtils.provideMainViewModelFactory()
    viewModel = ViewModelProviders.of(this, factory).get(MainViewModel::class.java)

    binding.let {
        it.viewModel = viewModel
        it.setLifecycleOwner(this@MainFragment)
    }

    sharedViewModel = activity?.run {
        ViewModelProviders.of(this).get(SharedNewPostViewModel::class.java)
    } ?: throw Exception("Invalid activity")

    return binding.root
}

override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
    super.onViewCreated(view, savedInstanceState)

    val pagerAdapter = MainPagerAdapter(childFragmentManager)

    viewPager.adapter = pagerAdapter
    tabLayout.setupWithViewPager(viewPager)
}

}

1 Ответ

0 голосов
/ 04 февраля 2019

необходимо проверить уже savedInstanceState в Activity.onCreate():

if(savedInstanceState == null) {
    ...
}

, а когда это не null, не раздувать Fragment, что впоследствии не вызовет Fragment.onCreateView() дважды (иначе трудно вернуть View оттуда).

...