Open Kotaro666-dev opened 3 years ago
Androidの哲学として、Fragment自体に状態を保持する必要はなく、保持しておきたい状態があれば ViewModel などで保持しておく。 そうすれば、Fragmentが破棄されて、再生成されても、ViewModelからデータを復元させることができるイメージ。
各ボトムバータブの中のスタックを維持する方法について つまり、各タブバーのフラグメントのインスタンスを保持する方法?
各ボトムバータブ押下でのタブ遷移で、スタックが積まれていく構造をどうにかしたい。 メルカリさんのように、「戻る」タブを押下したら、単純に「ホーム」タブにだけPOPしてほしい。
BottomNavigationViewコンポーネント
懸念点
BottomNavigationViewの各メニューアイテムはそれぞれフラグメントで作成し、かつ状態を保持したい。
こちらの資料で紹介されている、「FragmentPagerAdapterを継承したViewPagerクラス」を活用した方法で解決できそう。
FragmentPagerAdapter
FragmentPagerAdapter
こちらの FragemntPagerAdapterは Depricated されているようで、ViewPager2 と FragmentStateAdapter を使用するように公式でアナウンスされている。
FragmentStateAdapterを使った実装
以下の資料が参考になりそう。
BottomNavigationView と ViewPager2 を使って、フラグメント再生成を行った場合のデメリット
各フラグメントのインスタンス化は、FragmentStateAdapter が MainAcitivity でインスタンス可されるときに実行される。 そのため、初めてフラグメントのページに訪問した時にインスタンス可されない。
そのことから、例としてホーム画面が生成された時に各画面のフラグメントのインスタンスが生成されてしまうため、各画面にて行いたいAPI通信が最初にすべて実行されてしまう問題がある。'
saveFragmentInstanceState を使って、各フラグメントの状態を保持しておく
以下の記事を参考にする
参考資料
Show/Hide
【Android】Fragmentを使うときのコツとか色々
Fragmentをhideすることは、アプリのパフォーマンス的にあまり良くないとのこと
FragmentTransaction.hide()- findings
参考資料