У меня есть MainActivity, которая содержит три вкладки. На каждой вкладке отображаются данные, взятые из списка SQLite db в виде списка с использованием RecyclerView.RecyclerView: адаптер не прилагается; пропуская макет - ошибка внутри фрагмента
Когда я впервые запускаю приложение, данные отображаются правильно. После того, как я вернусь к ранее открытой вкладке, данных там нет.
Проблема начали появляться после того, как я реализовал следующие:
- Проверьте, если адаптер является недействительным.
- Если да, создайте экземпляр адаптера и заполните его данными.
- Если нет, просто обновить данные внутри адаптера и вызвать
notifyDataSetChanged()
Эта идея работала в другом проекте, где я должен был сделать то же самое с деятельности. В этом случае у меня есть фрагмент. Я только что узнал, что Fragment имеет другое поведение в жизненном цикле.
Как я могу решить эту проблему?
Один из класса вкладок:
public class AllTabView extends Fragment {
Context ourContext;
RecyclerView mList;
AllAdapter adapter;
RecyclerView.LayoutManager layoutManager;
TextView mEmptyText;
long movedItem, draggedItem;
ArrayList<ArrayList<String>> mDays;
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
View v1 = inflater.inflate(R.layout.list_view_content, container, false);
mList = (RecyclerView) v1.findViewById(R.id.recycler_view);
mEmptyText = (TextView) v1.findViewById(R.id.empty_text);
ourContext = getContext();
layoutManager = new LinearLayoutManager(ourContext);
mList.setLayoutManager(layoutManager);
RecyclerView.ItemAnimator itemAnimator = new DefaultItemAnimator();
mList.setItemAnimator(itemAnimator);
return v1;
}
@Override
public void onResume() {
super.onResume();
getDays();
if (mDays.size() == 0) {
mList.setVisibility(View.GONE);
mEmptyText.setVisibility(View.VISIBLE);
} else {
mList.setVisibility(View.VISIBLE);
mEmptyText.setVisibility(View.GONE);
if(adapter == null) {
Log.v(TAG, "adapter null");
adapter = new AllAdapter(ourContext, mDays);
}
else {
Log.v(TAG, "notify");
adapter.updateData(mDays);
}
mList.setAdapter(adapter);
}
}
public void getDays() {
DaysDatabase info = new DaysDatabase(ourContext);
info.open();
mDays = info.getData();
info.close();
}
public void setAdapter() {
adapter = new AllAdapter(ourContext, mDays);
mList.setAdapter(adapter);
}
}
MainActivity, который содержит фрагменты:
public class MainActivity extends AppCompatActivity {
FragmentTabHost mFragmentTabHost;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
mFragmentTabHost = (FragmentTabHost) findViewById(android.R.id.tabhost);
mFragmentTabHost.setup(MainActivity.this, getSupportFragmentManager(), android.R.id.tabcontent);
String tag1 = "all";
String tag2 = "since";
String tag3 = "until";
final View tabView1 = createTabView(MainActivity.this, "All");
final View tabView2 = createTabView(MainActivity.this, "Since");
final View tabView3 = createTabView(MainActivity.this, "Until");
mFragmentTabHost.addTab(mFragmentTabHost.newTabSpec(tag1).setIndicator(tabView1).setContent(new FragmentTabHost.TabContentFactory() {
public View createTabContent(String tag1) {
return tabView1;
}
}), AllTabView.class, null);
mFragmentTabHost.addTab(mFragmentTabHost.newTabSpec(tag2).setIndicator(tabView2).setContent(new FragmentTabHost.TabContentFactory() {
public View createTabContent(String tag2) {
return tabView2;
}
}), SinceTabView.class, null);
mFragmentTabHost.addTab(mFragmentTabHost.newTabSpec(tag3).setIndicator(tabView3).setContent(new FragmentTabHost.TabContentFactory() {
public View createTabContent(String tag1) {
return tabView3;
}
}), UntilTabView.class, null);
mFragmentTabHost.getTabWidget().setDividerDrawable(R.drawable.tab_divider);
}
private static View createTabView(final Context context, final String text) {
View view = LayoutInflater.from(context).inflate(R.layout.tabs_bg, null);
TextView tv = (TextView) view.findViewById(R.id.tabsText);
tv.setText(text);
return view;
}
Попробуйте установить журнал в 'getDays()' метод для проверки, является ли размер mDays (после того, как установлено) равен 0. Таким образом, вы (и мы) можем знать, является ли проблема в этом методе или адаптер 'UpdateData 'метод. И добавьте код адаптера, чтобы ответить тоже – rsella
Пожалуйста, внесите свой код активности, в котором вы обрабатываете фрагменты. –
Как я понял, когда я перехожу на другую вкладку, активная вкладка вызывает 'onPause',' onStop' и 'onDestroyView'. Поэтому мы теряем состояние recyclerView. Когда я вернусь на вкладку, он снова инициализирует recyclerView. Здесь он не знает, что он был прикрепленным адаптером раньше. – Marat