![](/img/trans.png)
[英]Android shared element transition between an activity with a fragment to another activity with a fragment
[英]ImageView Shared Element Transition between Fragment and Activity
我正在viewpager中显示电影的图像。 每当用户选择图像时,将对其进行动画处理(调整大小)并在另一个活动上进行绘制。 问题是我无法正确实现动画。
这是我的viewpager(在MoviesPager.java片段中)的代码:
View v = inflater.inflate(R.layout.pager_fragment, container, false);
poster = (ImageView) v.findViewById(R.id.selectedMoviePoster);
final View sharedView=poster;
final String transitionName=y.getOriginalTitle();
ActivityCompat.startActivity(getActivity(),sendMovie, ActivityOptions.makeSceneTransitionAnimation(getActivity(),sharedView,transitionName).toBundle());
这里“ y”是将要显示的电影对象。
这是MainActivity.java的代码,在其中实现了viewpager:
getWindow().requestFeature(Window.FEATURE_ACTIVITY_TRANSITIONS);//=<item name="android:windowActivityTransitions">true</item>*/
getWindow().setExitTransition(new Fade());//=<item name="android:windowExitTransition">@transition/fade</item>
getWindow().setSharedElementExitTransition(new ChangeImageTransform());//same as above
这是Movie.java的代码,它显示电影详细信息
getWindow().requestFeature(Window.FEATURE_ACTIVITY_TRANSITIONS);
getWindow().setEnterTransition(new Fade());
getWindow().setSharedElementEnterTransition(new ChangeImageTransform());
过渡名称设置为:
1)在activity_main.xml中
<android.support.v4.view.ViewPager
android:id="@+id/currentMoviesViewPager"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:transitionName="viewPagerTransition"/>
2)在activity_movie.xml中
<android.support.design.widget.AppBarLayout
android:id="@+id/appbar"
android:layout_width="match_parent"
android:layout_height="300dp"
android:fitsSystemWindows="true"
android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">
<android.support.design.widget.CollapsingToolbarLayout
android:id="@+id/collapsing_toolbar"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
app:contentScrim="?attr/colorAccent"
app:expandedTitleMarginEnd="64dp"
app:expandedTitleMarginStart="48dp"
app:layout_scrollFlags="scroll">
<ImageView
android:id="@+id/selectedMoviePoster"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:layout_collapseMode="parallax"
app:layout_collapseParallaxMultiplier="1"/>
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
app:layout_collapseMode="pin"
app:popupTheme="@style/ThemeOverlay.AppCompat.Light"/>
<View
android:layout_width="match_parent"
android:layout_height="10dp"
android:background="@android:color/white"
app:layout_collapseMode="parallax"
app:layout_collapseParallaxMultiplier="1"/>
</android.support.design.widget.CollapsingToolbarLayout>
</android.support.design.widget.AppBarLayout>
3)在pager_fragment.xml中 ,它是viewpager片段的xml
<android.support.v7.widget.CardView
xmlns:card_view="http://schemas.android.com/apk/res-auto"
android:id="@+id/card_view"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_gravity="center"
card_view:cardElevation="40dp"
card_view:cardCornerRadius="4dp"
android:clipChildren="false"
android:clipToPadding="false">
<ImageView
android:id="@+id/selectedMoviePoster"
android:layout_width="match_parent"
android:layout_height="match_parent"/>
<ProgressBar
android:id="@+id/loadPosterProgress"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"/>
</android.support.v7.widget.CardView>
我在两个活动中都使用Universal Image Loader来下载和显示图像。
另外,如果可以,我可以在加载之前存储图像,这样就不必每次都下载。 将图像调整为imageview的大小也无法正常工作。
我为这两个活动使用了两个不同的主题,这是代码。
4) styles.xml :
<resources>
<!-- Base application theme. -->
<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
<!-- Customize your theme here. -->
<item name="colorPrimary">@color/colorPrimary</item>
<item name="colorPrimaryDark">@color/colorPrimaryDark</item>
<item name="colorAccent">@color/colorAccent</item>
<item name="android:windowBackground">@android:color/darker_gray</item>
<item name="android:windowContentTransitions">true</item>
</style>
<style name="Theme.AppCompat.Light.FullScreen">
<item name="windowNoTitle">true</item>
<item name="windowActionBar">false</item>
<item name="android:windowBackground">@android:color/darker_gray</item>
<item name="android:windowContentTransitions">true</item>
</style>
您可以为该过渡做些什么:
View sharedView = holder.event_pic;
String transitionName = mContext.getString(R.string.event_image);
Intent intent_event_description = new Intent(mContext, EventDescription.class);
if (Build.VERSION.SDK_INT >= 21) {
ActivityOptions transitionActivityOptions = ActivityOptions.makeSceneTransitionAnimation(activity, sharedView, transitionName);
mContext.startActivity(intent_event_description, transitionActivityOptions.toBundle());
}
确保为两个图像提供相同的ID。
在您的风格主题中:
<item name="android:windowContentTransitions">true</item>
请为两个图像提供相同的过渡名称:
<ImageView
android:id="@+id/selectedMoviePoster"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:layout_collapseMode="parallax"
android:transitionName="selectedMoviePoster"
app:layout_collapseParallaxMultiplier="1"/>
<ImageView
android:id="@+id/selectedMoviePoster"
android:layout_width="match_parent"
android:transitionName="selectedMoviePoster"
android:layout_height="match_parent"/>
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.