2016-12-30 46 views
0

我使用ViewPager加載不同的頁面。這些應由CollapsingToolbarLayout組成。CollapseingToolbarLayout ViewPager內

<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent"> 


    <android.support.v4.view.ViewPager 
     xmlns:android="http://schemas.android.com/apk/res/android" 
     android:id="@+id/pager" 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" /> 

</FrameLayout> 

一旦膨脹,佈局應是這樣工作的:

它應允許通過頁面滑動和每一頁都有其工具欄上的圖片可以單獨崩潰。這可能嗎?

<?xml version="1.0" encoding="utf-8"?> 
<android.support.design.widget.CoordinatorLayout 
    xmlns:android="http://schemas.android.com/apk/res/android" 
    xmlns:app="http://schemas.android.com/apk/res-auto" 
    xmlns:tools="http://schemas.android.com/tools" 
    android:id="@+id/root_container" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    android:fitsSystemWindows="true" 
    android:background="@color/background" 
    android:transitionName="@string/transition_session_background"> 

    <android.support.design.widget.AppBarLayout 
     android:id="@+id/appbar" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     android:background="@null" 
     android:fitsSystemWindows="true"> 

     <android.support.design.widget.CollapsingToolbarLayout 
      android:id="@+id/collapsing_toolbar" 
      android:layout_width="match_parent" 
      android:layout_height="wrap_content" 
      app:layout_scrollFlags="scroll" 
      android:minHeight="1px" 
      android:fitsSystemWindows="true" 
      android:background="@null" 
      app:titleEnabled="false"> 



       <ImageView 
        android:id="@+id/photo" 
        android:layout_width="match_parent" 
        android:layout_height="match_parent" 
        android:scaleType="centerCrop" 
        android:transitionName="@string/transition_session_image" /> 



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



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

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

    <android.support.v4.widget.NestedScrollView 
     android:id="@+id/scroll_view" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     app:layout_behavior="@string/appbar_scrolling_view_behavior" 
     android:clipToPadding="false"> 


    </android.support.v4.widget.NestedScrollView> 


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

回答

0

它應允許通過網頁和每一頁刷在 其工具欄上的圖片可以單獨塌陷。這可能嗎?

不,不幸的是,每個viewpager頁面都有自己的狀態的工具欄是不可能的。原因很容易理解,因爲viewpager是viewpager和viewpager獨立工作的viewplager,它是一個等同層次的視圖。

雖然每次在viewpager中更改頁面時都可以使用應用程序,但工具欄仍處於摺疊或展開狀態。 爲了實現這一目標建立viewpager對頁面變化監聽

// Attach the page change listener inside the activity 
vpPager.addOnPageChangeListener(new OnPageChangeListener() { 

    // This method will be invoked when a new page becomes selected. 
    @Override 
    public void onPageSelected(int position) { 
     appBarLayout.setExpanded(true);//or false as you wish 
    } 


}); 

使用支持庫V23,你可以在你使用onPageSelected()重寫方法調用appBarLayout.setExpanded(真/假)。

0

可以使用Collapsing toolbarviewpagerTablayout

<?xml version="1.0" encoding="utf-8"?> 
<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:fitsSystemWindows="true"> 

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

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

      //your image view under toolbar 
      <ImageView 
       android:id="@+id/header" 
       android:layout_width="match_parent" 
       android:layout_height="match_parent" 
       android:src="@drawable/test" 
       android:fitsSystemWindows="true" 
       android:scaleType="centerCrop" 
       app:layout_collapseMode="parallax" /> 

      <android.support.v7.widget.Toolbar 
       android:id="@+id/toolbar" 
       android:layout_width="match_parent" 
       android:layout_height="100dp" 
       android:gravity="top" 
       android:minHeight="?attr/actionBarSize" 
       app:layout_collapseMode="pin" 
       app:popupTheme="@style/ThemeOverlay.AppCompat.Light" 
       app:titleMarginTop="15dp" /> 

      <android.support.design.widget.TabLayout 
       android:id="@+id/tabs" 
       android:layout_width="match_parent" 
       android:layout_height="?attr/actionBarSize" 
       android:layout_gravity="bottom" 
       app:tabIndicatorColor="@color/colorAccent" /> 

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

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

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


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

這裏是一個很好的實現示例: http://manishkpr.webheavens.com/android-material-design-tabs-collapsible-example/