2016-07-06 6 views
-1

私は3つのタブを保持するMainActivityを持っています。各タブでは、RecyclerViewを使用してリストとしてSQLite dbから取得したデータを表示しています。RecyclerView:アダプターは接続されていません。レイアウトのスキップ - フラグメント内部のエラー

初めてアプリを起動すると、データが正しく表示されます。私が以前に開いたタブに戻ると、そこにデータはありません。アダプタがnullの場合

  1. はチェック:

    問題は、私は次のように実装した後に表示されるようになりました。

  2. 「はい」の場合は、adapterインスタンスを作成し、それにデータを入力します。
  3. noの場合、単にアダプタの内部データを更新し、このアイデアは私が活動して同じことをしなければならなかった他のプロジェクトで働いていたnotifyDataSetChanged()

を呼び出します。この場合、私は断片を持っています。私は、断片にライフサイクルの動作が異なることを知りました。

どうすればこの問題を解決できますか?タブクラスの

ワン:断片を保持している

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

mDaysのサイズ(設定後)が0であるかどうかをチェックするためのgetDays()メソッドのログを設定してみてください。問題がそのメソッドか、 'メソッド。さらに、回答するアダプタコードを追加してください – 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の上のコードで、ArrayListにnullpointerexceptionをスローしないようにします。 – Drv

+0

私は更新しました。チェックアウト。 –

+0

'ViewPager'で' FragmentPagerAdapter'を使ってタブビューを設定することをお勧めします。 –

関連する問題