2015-10-26 16 views
5

Mam układ jak ten na zdjęciu poniżejAndroid Shared element przejściowy, źle pozycja początkowa

enter image description here

gdzie ramka pomarańczowy jest HostFragment jest zbudowany tak:

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

      <android.support.v7.widget.Toolbar 
       android:id="@id/toolbar" 
       android:layout_width="match_parent" 
       android:layout_height="?attr/actionBarSize" 
       app:layout_scrollFlags="scroll|enterAlways" 
       app:popupTheme="@style/ThemeOverlay.AppCompat.Light" 
       app:titleMarginStart="68dp" 
       /> 

      <de.halfbit.audiopie.ui.common.views.SlidingTabs 
       android:id="@id/tabs" 
       android:layout_width="match_parent" 
       android:layout_height="?attr/actionBarSize" 
       app:slidingTabsIndicatorColor="@color/accent" 
       /> 

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

a niebieska ramka to dziecko ItemsFragment zawierające w sobie ItemsFragment.

Po kliknięciu kafelka w RecyclerView zastępuję HostFragment innym fragmentem, który przypuszczalnie udostępnia kliknięty obraz. I to zrobić stosując wspólny element przejściowy w następujący sposób:

FragmentManager fm = getChildFragmentManager(); 
Fragment fragment = ContentFragment.newInstance(); 

AutoTransition autoTransition = new AutoTransition(); 
autoTransition.setDuration(3000); 
fragment.setSharedElementEnterTransition(autoTransition); 

fm.beginTransaction() 
    .replace(R.id.library, fragment) 
    .addSharedElement(view, "cover") 
    .commit(); 

Współpracuje obok jednej rzeczy: początkową pozycję płytki pokrywy gdy animacja rozpoczyna się w ContentFragment jest źle (see this screen cast video) - to niepożądany dno offset.

Wizualnie to przesunięcie wygląda na równi z wysokością paska zakładek o numerze HostFragment. Czy macie pojęcie, jak uniknąć tego przesunięcia?

Warto również wspomnieć, że wszystkie dzieci z serii RecyclerView's mają unikatowe transitionNames.

+0

Czy próbowałeś wyizolować problem, aby sprawdzić, czy jest on spowodowany przez 'CoordinatorLayout'? Jest to klasa buggy, więc spróbowałbym uruchomić animację w prostym rodzicielstwie 'FrameLayout' i sprawdzić, czy problem nadal występuje. –

+2

@PaulBurke Dzięki za zaglądanie. Jestem trochę zaniepokojony ilością problemów w najnowszych bibliotekach wsparcia i projektowania. Postanowiłem więc na razie użyć innego rodzaju animacji. Potrzebuję trochę czasu, żeby się uspokoić, a potem spróbuję wyizolować problem. –

Odpowiedz

0

Wiem, że to pytanie jest starożytne, ale walczę z podobnym problemem.

W końcu wszystko, co musiałem zrobić, to zmienić flagę android: clipChildren w widoku nadrzędnym xml na false.

Powiązane problemy