6

Я использую CollapsingToolbarLayout с двумя изображениями внутри, один для фона и один как верхний логотип. Идея состоит в том, чтобы сделать их параллаксом. Эта вещь отлично работает на Android 5 в физических устройствах, но не на устройствах (или эмуляторах) с более низкими версиями. Вид странный.ImageView внутри CollapsingToolbarLayout не отображается на некоторых устройствах

Это мой макет:

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

ответ

8

Я нашел способ, чтобы заставить его работать. Кажется, что-то не так с представлениями с wrap_content внутри CollapsingToolbarLayout в < 5 версиях для Android. Переход на match_parent и использование scale_type = "center", чтобы сделать изображение в центре, действительно помогло решить мою проблему.

Это как изменения макета изображения:

<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" 
    /> 
Смежные вопросы