6

Używam CollapsingToolbarLayout z dwoma obrazami wewnątrz, jednym dla tła i jednym dla górnego logo. Chodzi o to, aby uczynić z nich zarówno paralaksy. To działa dobrze na Androidzie 5 na urządzeniach fizycznych, ale nie na urządzeniach (lub emulatorach) o niższych wersjach. Coś dziwnego.ImageView inside CollapsingToolbarLayout niewidoczny w niektórych urządzeniach

To mój układ:

<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"> 

    <NestedScrollView 
     android:id="@+id/scroll" 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" 
     app:layout_behavior="@string/appbar_scrolling_view_behavior" > 

     <FrameLayout 
      android:id="@+id/fragment_container" 
      android:layout_width="match_parent" 
      android:layout_height="match_parent" 
      android:orientation="vertical" 
      android:background="#fff"> 

      <!--content--> 
     </FrameLayout> 

    </NestedScrollView> 

    <android.support.design.widget.AppBarLayout 
     android:id="@+id/appbar" 
     android:layout_width="match_parent" 
     android:layout_height="400dp" 
     android:background="#222"> 

     <android.support.design.widget.CollapsingToolbarLayout 
      android:layout_width="match_parent" 
      android:layout_height="match_parent" 
      app:layout_scrollFlags="scroll"> 
      <ImageView 
       android:id="@+id/header_bk" 
       android:layout_width="match_parent" 
       android:layout_height="match_parent" 
       android:src="@drawable/background" 
       android:scaleType="centerCrop" 
       app:layout_collapseMode="parallax" 
       app:layout_collapseParallaxMultiplier="0.7" 
       /> 
      <ImageView 
       android:id="@+id/header_logo" 
       android:layout_width="wrap_content" 
       android:layout_height="wrap_content" 
       android:layout_gravity="center" 
       android:src="@drawable/ic_logo" 
       app:layout_collapseMode="parallax" 
       android:background="#44ff0000" 
       /> 
     </android.support.design.widget.CollapsingToolbarLayout> 
    </android.support.design.widget.AppBarLayout> 
</android.support.design.widget.CoordinatorLayout> 

Odpowiedz

8

znalazłem sposób, aby to działało. Wygląda na coś nie tak z widokami z wrap_content wewnątrz CollapsingToolbarLayout w wersji < 5 wersji Androida. Zmiana na match_parent i użycie scale_type = "center", aby obraz pozostał na środku, rozwiązał mój problem.

ten sposób zmienia układ obrazu:

<ImageView 
    android:id="@+id/header_logo" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    android:scaleType="center" 
    android:layout_gravity="center" 
    android:src="@drawable/ic_adi_logo" 
    app:layout_collapseMode="parallax" 
    /> 
Powiązane problemy