2016-07-06 2 views
-1

У меня есть MainActivity, которая содержит три вкладки. На каждой вкладке отображаются данные, взятые из списка SQLite db в виде списка с использованием RecyclerView.RecyclerView: адаптер не прилагается; пропуская макет - ошибка внутри фрагмента

Когда я впервые запускаю приложение, данные отображаются правильно. После того, как я вернусь к ранее открытой вкладке, данных там нет.

Проблема начали появляться после того, как я реализовал следующие:

  1. Проверьте, если адаптер является недействительным.
  2. Если да, создайте экземпляр адаптера и заполните его данными.
  3. Если нет, просто обновить данные внутри адаптера и вызвать 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; 
} 
+0

Попробуйте установить журнал в 'getDays()' метод для проверки, является ли размер mDays (после того, как установлено) равен 0. Таким образом, вы (и мы) можем знать, является ли проблема в этом методе или адаптер 'UpdateData 'метод. И добавьте код адаптера, чтобы ответить тоже – rsella

+0

Пожалуйста, внесите свой код активности, в котором вы обрабатываете фрагменты. –

+1

Как я понял, когда я перехожу на другую вкладку, активная вкладка вызывает 'onPause',' onStop' и 'onDestroyView'. Поэтому мы теряем состояние recyclerView. Когда я вернусь на вкладку, он снова инициализирует recyclerView. Здесь он не знает, что он был прикрепленным адаптером раньше. – Marat

ответ

1

Я редактировал свой код. Взгляни, пожалуйста.

public class AllTabView extends Fragment { 

Context ourContext; 

RecyclerView mList; 
AllAdapter adapter; 
RecyclerView.LayoutManager layoutManager; 
TextView mEmptyText; 

long movedItem, draggedItem; 

ArrayList<ArrayList<String>> mDays = new ArrayList<>(); 

@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); 
    getDays(); 
    RecyclerView.ItemAnimator itemAnimator = new DefaultItemAnimator(); 
    mList.setItemAnimator(itemAnimator); 
    adapter = new AllAdapter(ourContext, mDays); 
    mList.setAdapter(adapter); 
    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); 
    } 
} 

public void getDays() { 
    DaysDatabase info = new DaysDatabase(ourContext); 
    info.open(); 
    mDays.clear(); 
    mDays.addAll(info.getData()); 
    if (adapter != null) 
     adapter.notifyDataSetChanged(); 
    info.close(); 
} 
} 
+0

Просто добавьте mDays = new ArrayList(); в вышеприведенном коде в onCreatView, чтобы он не выбрал исключение nullpointer в вашем ArrayList. – Drv

+0

Я обновил. Проверять, выписываться. –

+0

Я бы предложил вам использовать 'FragmentPagerAdapter' с' ViewPager' для настройки табуляции. –

Смежные вопросы