5

Grałem z biblioteką wsparcia projektowania i napotkano mały problem, który mam nadzieję, że ktoś może mi pomóc.Viewpager nie pojawia się podczas używania CollapsingToolbarLayout

Używam CollapsingToolbar, który zawiera ImageView, który zwija się w parahalax. Na pasku CollapsingToolbar mam również TabLayout, który ma przewinąć mój ViewPager. Mój problem polega na tym, że ViewPager nie pojawia się. Problem wydaje się pojawiać tylko wtedy, gdy ustawię ViewPager układ_height na match_parent lub wrap_content. Jeśli ustawię go na 600dp, problem zniknie, ale wtedy widok kończy się na ustalonej długości, która nie jest zbyt ładna.

Każda pomoc zostanie doceniona!

Oto mój 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:id="@+id/main_content" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    android:fitsSystemWindows="true"> 

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

    <android.support.design.widget.CollapsingToolbarLayout 
     android:id="@+id/collapsing_toolbar" 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" 
     app:layout_scrollFlags="scroll|exitUntilCollapsed" 
     android:fitsSystemWindows="true" 
     app:contentScrim="?attr/colorPrimary" 
     > 

     <ImageView 
      android:id="@+id/backdrop" 
      android:layout_width="match_parent" 
      android:layout_height="match_parent" 
      android:fitsSystemWindows="true" 
      app:layout_collapseMode="parallax" 
      android:src="@drawable/stock_image"/> 

     <android.support.v7.widget.Toolbar 
      android:id="@+id/toolbar" 
      android:layout_width="match_parent" 
      android:layout_height="?attr/actionBarSize" 
      app:popupTheme="@style/ThemeOverlay.AppCompat.Light" 
      android:layout_gravity="top" 
      /> 

     <android.support.design.widget.TabLayout 
      android:id="@+id/tabs" 
      android:layout_width="match_parent" 
      android:layout_height="wrap_content" 
      android:layout_gravity="bottom"/> 

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

    </android.support.design.widget.AppBarLayout> 
    <android.support.v4.widget.NestedScrollView 
    android:layout_width="match_parent" 
    android:layout_height="match_parent"> 

    <LinearLayout 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" 
     android:orientation="vertical" 
     > 

     <android.support.v4.view.ViewPager 
      android:id="@+id/viewpager" 
      android:layout_width="match_parent" 
      android:layout_height="match_parent" 
      android:background="@android:color/white" 
      app:layout_behavior="@string/appbar_scrolling_view_behavior" 
      /> 
    </LinearLayout> 
    </android.support.v4.widget.NestedScrollView> 

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

Odpowiedz

8

Należy usunąć poziomy NestedScrollView i LinearLayout między CoordinatorLayout i ViewPager:

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

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

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

Widok z app:layout_behavior="@string/appbar_scrolling_view_behavior musi być bezpośrednim dzieckiem CoordinatorLayout być ustawione poprawnie w odniesieniu do AppBarLayout.

+0

Usunięcie tych "NestedScrollView" i "LinearLayout" rozwiązuje problem, tzn. Widok "ViewPager" jest teraz widoczny. Pojawia się jednak inny problem: nie mogę przewinąć pionowo widoku "ViewPager", dlatego przede wszystkim miałem tam te widoki. Wszelkie sugestie, aby to naprawić? – Adam

+1

@Adam - możesz dodać "NestedScrollView" do każdej strony, jeśli jej potrzebujesz. – ianhanniballake

+2

Dzięki za pomoc. Skoncentrowałem się na umieszczeniu NestedScrollViews w fragmentach mojego ViewPagera zamiast w obrębie samego ViewPagera i wykonałem zadanie! – Adam

Powiązane problemy