0

この問題は苦労しています。フラグメントのRelativeLayout - >アクティビティ内のAppBar(フラグメントオーバーレイツールバー)

私はツールバー(2と1のTAB)でアクティビティを持っています。しかし、RecyclerViewを使ってFragmentを作成した後、このRecyclerViewはツールバーを無視し、全画面(全面/前面)に表示されます。

fragment_category.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    xmlns:app="http://schemas.android.com/apk/res-auto" 
    android:layout_width="match_parent" 
    android:id="@+id/relativelayout_recycler" 
    android:layout_height="match_parent"> 
    <android.support.v4.widget.SwipeRefreshLayout 
     android:id="@+id/swipe_refresh_layout" 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" 
> 
    <android.support.v7.widget.RecyclerView 
     android:id="@+id/recycler" 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" 
     android:padding="@dimen/spacing_small" 
     android:scrollbars="vertical" 
     app:layout_behavior="@string/appbar_scrolling_view_behavior" /> 
    </android.support.v4.widget.SwipeRefreshLayout> 

</RelativeLayout> 

activity_main.xml

<RelativeLayout 
    android:id="@+id/main_content" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent"> 

    <android.support.design.widget.CoordinatorLayout 
     android:layout_width="match_parent" 
     android:layout_height="match_parent"> 

     <android.support.design.widget.AppBarLayout 
      android:id="@+id/appbar" 
      android:layout_width="match_parent" 
      android:layout_height="wrap_content" 
      android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"> 

      <FrameLayout 
       android:layout_width="match_parent" 
       android:layout_height="?attr/actionBarSize" 
       app:layout_scrollFlags="enterAlways"> 

       <include layout="@layout/toolbar" /> 

      </FrameLayout> 

      <View 
       android:id="@+id/toolbar_delimiter" 
       android:layout_width="match_parent" 
       android:layout_height="1px" 
       android:background="@color/view_background" 
       android:visibility="gone" 
       app:layout_scrollFlags="scroll|enterAlways|snap" /> 

      <FrameLayout 
       android:id="@+id/frame_filters_toolbar" 
       android:layout_width="match_parent" 
       android:layout_height="?attr/actionBarSize" 
       android:visibility="gone" 
       app:layout_scrollFlags="scroll|enterAlways|snap"> 

       <include layout="@layout/toolbar_filters" /> 

      </FrameLayout> 

      <android.support.design.widget.TabLayout 
       android:id="@+id/tabs" 
       android:layout_width="match_parent" 
       android:layout_height="wrap_content" 
       app:tabGravity="fill" 
       app:tabMode="fixed" /> 

     </android.support.design.widget.AppBarLayout> 

     <FrameLayout 
      android:id="@+id/frame_content" 
      android:layout_width="match_parent" 
      android:layout_height="match_parent" 
      android:layout_below="@+id/tabs" 
      android:visibility="gone" 
      app:layout_behavior="@string/appbar_scrolling_view_behavior" /> 


    </android.support.design.widget.CoordinatorLayout> 

    <android.support.v4.view.ViewPager 
     android:id="@+id/viewpager" 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" 
     app:layout_behavior="@string/appbar_scrolling_view_behavior" /> 

    <android.support.design.widget.FloatingActionButton 
     android:id="@+id/fab" 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:layout_alignParentBottom="true" 
     android:layout_alignParentRight="true" 
     android:layout_margin="@dimen/spacing_large" 
     android:clickable="true" 
     android:src="@drawable/ic_no_item" 
     android:tint="@android:color/white" /> 


</RelativeLayout> 

の一部FragmentCategory.java

@Override 
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { 
    view = inflater.inflate(R.layout.fragment_category, null); 
    context = getActivity(); 
    // activate fragment menu 
    setHasOptionsMenu(true); 

    db = new DatabaseHandler(getActivity()); 
    sharedPref = new SharedPref(getActivity()); 

    resolveCategory(); 

    lyt_not_found = view.findViewById(R.id.lyt_not_found); 
    recyclerView = (RecyclerView) view.findViewById(R.id.recycler); 
    recyclerView.setLayoutManager(new GridLayoutManager(getActivity(), Tools.getGridSpanCount(getActivity()))); 
    recyclerView.addOnScrollListener(new RecyclerView.OnScrollListener() { 
     @Override 
     public void onScrollStateChanged(RecyclerView v, int state) { 
      super.onScrollStateChanged(v, state); 
      if(state == RecyclerView.SCROLL_STATE_DRAGGING || state == RecyclerView.SCROLL_STATE_SETTLING){ 
       ActivityMain.animateFab(true); 
      } else { 
       ActivityMain.animateFab(false); 
      } 
     } 
    }); 
    swipeLayout = (SwipeRefreshLayout) view.findViewById(R.id.swipe_refresh_layout); 
    swipeLayout.setOnRefreshListener(this); 
    swipeLayout.setColorSchemeResources(
      R.color.colorAccent, R.color.colorAccentDark); 
    displayDataFromDatabase(); 
    return view; 
} 

私はちょうどいくつかの愚かな間違いをしていますが、私ができることを知っていますそれだけを把握していない。私の貧しい英語とスキルには申し訳ありません。あなたが私を助けてくれたらありがとう。

+0

レイアウトを最初から作り直してみましたか?コーディネーターのレイアウトの外でRelativeLayoutが必要ないことはわかりません。 ViewPagerとコーディネータのレイアウトは全く同じサイズに設定されているためです。 –

+0

どのような出力が期待されているのか分かりませんが、 'RelativeLayout'の子どもたちは' match_parent'を使い、 'FAB'親は' CoordinatorLayout'でなければなりません。 – Enzokie

+0

これは、frame_contentのFrameLayout要素をViewPagerに置き換える必要がある場合、 –

答えて

1

activity_main.xmlをこれに変更することができます。

<android.support.design.widget.CoordinatorLayout 
    xmlns:android="http://schemas.android.com/apk/res/android" 
    xmlns:app="http://schemas.android.com/apk/res-auto" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent"> 

    <android.support.design.widget.AppBarLayout 
     android:id="@+id/appbar" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"> 

     <FrameLayout 
      android:layout_width="match_parent" 
      android:layout_height="?attr/actionBarSize" 
      app:layout_scrollFlags="enterAlways"> 

      <include layout="@layout/toolbar"/> 

     </FrameLayout> 

     <View 
      android:id="@+id/toolbar_delimiter" 
      android:layout_width="match_parent" 
      android:layout_height="1px" 
      android:background="@color/view_background" 
      android:visibility="gone" 
      app:layout_scrollFlags="scroll|enterAlways|snap"/> 

     <FrameLayout 
      android:id="@+id/frame_filters_toolbar" 
      android:layout_width="match_parent" 
      android:layout_height="?attr/actionBarSize" 
      android:visibility="gone" 
      app:layout_scrollFlags="scroll|enterAlways|snap"> 

      <include layout="@layout/toolbar_filters"/> 

     </FrameLayout> 

     <android.support.design.widget.TabLayout 
      android:id="@+id/tabs" 
      android:layout_width="match_parent" 
      android:layout_height="wrap_content" 
      app:tabGravity="fill" 
      app:tabMode="fixed"/> 

    </android.support.design.widget.AppBarLayout> 

    <FrameLayout 
     android:id="@+id/frame_content" 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" 
     android:layout_below="@+id/tabs" 
     android:visibility="gone" 
     app:layout_behavior="@string/appbar_scrolling_view_behavior"/> 

    <android.support.v4.view.ViewPager 
     android:id="@+id/viewpager" 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" 
     app:layout_behavior="@string/appbar_scrolling_view_behavior"/> 

    <android.support.design.widget.FloatingActionButton 
     android:id="@+id/fab" 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:layout_alignParentBottom="true" 
     android:layout_alignParentRight="true" 
     android:layout_gravity="end|bottom" 
     android:layout_margin="@dimen/spacing_large" 
     android:clickable="true" 
     android:src="@drawable/ic_no_item" 
     android:tint="@android:color/white"/> 

</android.support.design.widget.CoordinatorLayout> 

あなたはCoordinatorLayoutViewPagerFloatingActionButtonを追加することができます。

さらに、app:layout_behaviorを追加できます。

+0

素晴らしいことです。ありがとうございます:) – mousik

関連する問題