美文网首页
Day14-Activity动画

Day14-Activity动画

作者: 我不是死胖子 | 来源:发表于2017-09-07 16:03 被阅读157次

Activity动画

分为两种,

  • overridePendingTransition
  • ActivityOption

overridePendingTransition(enterAnim, exitAnim);

紧跟在 startActivity()/finish()之后

黑屏

当使用 overridePendingTransition(R.anim.right_to_current,0); 容易黑屏
解决: overridePendingTransition(R.anim.activity_open,R.anim.activity_stay);将activity的退出设置透明度从 1 到 1.

activity_stay.xml

<?xml version="1.0" encoding="utf-8"?>
<set  xmlns:android="http://schemas.android.com/apk/res/android">
    <alpha
        android:fromAlpha="1"
        android:toAlpha="1"
        android:duration="300"
        />
</set>

ActivityOption

  1. 在theme添加
<style name="AppTheme" parent="Theme.AppCompat">
    <item name="android:windowContentTransitions">true</item>
</style>
  1. 通过 startActivity(intent, bundle); 的 bundle 设置
ActivityOptions options = ActivityOptions.makeScaleUpAnimation(view, 0, 0, view.getWidth(), view.getHeight());
//ActivityOptionsCompat optionCompat = ActivityOptionsCompat.makeScaleUpAnimation(view,0,0,view.getWidth(),view.getHeight());
intent.putExtra("myserializabledata", persion);
startActivity(intent, optionCompat.toBundle());

五种静态方法创建动画

  1. makeCustomAnimation(Context context, int enterResId, int exitResId)
    效果: 与普通的overridePendingTransition差不多

    ActivityOptions options = ActivityOptions.makeCustomAnimation(
            MainActivity.this,  //传入的activity的上下文
            android.R.anim.slide_in_left,  //A Activity退出的效果
            android.R.anim.slide_out_right //B Activity进入的效果
            );
    
  2. makeScaleUpAnimation(View source,int startX, int startY, int startWidth, int startHeight)
    效果: 看到 B Activity 从相对于指定控件原点的指定位置, 按照指定大小不断扩大B Activity

    ActivityOptions options = ActivityOptions.makeScaleUpAnimation(
            iv_click,  //从A控件
            0,  //从A控件的宽度为0
            0,  //从A控件的高度为0
            iv_click.getWidth(), //打开的Activity最开始是多宽
            iv_click.getHeight() //打开的Activity最开始是多高
            );
    
  3. makeThumbnailScaleUpAnimation(View source,Bitmap thumbnail, int startX, int startY)
    效果: 和 2 相似, 只是放大的过程是指定的View放大, 最后才换成显示 B Activity

    ActivityOptions options = ActivityOptions.makeThumbnailScaleUpAnimation(
                           iv_click,
                           bitmap,
                           0,
                           iv_click.getHeight()
                   );
    
  4. makeSceneTransitionAnimation(Activity activity, View sharedElement, String sharedElementName)
    效果: 用于单个元素共享

    • 回退的时候如果还需要效果, 用 finishAfterTransition(); 替代finish();
    • 目标 Activity 可以是 SingleTask 但是不能指定 taskAffinity, 否则点击时闪屏, 但锁屏后再开, 却显示已经跳转到了B Activity.
    • 手机版本需要 Lolipop/5.0以上
    • 控件需要在Activity布局内,不能 listview 再 addHeadView Link
    • Theme 需要设置为android:Theme.Material 或者AppCompat

    注意: 报错 You need to use a Theme.AppCompat theme (or descendant) with this activity.如果你的Theme原来是 AppCompatActivity, 此时需要修改为Activity, 或者 如果有v4包的Fragment, 那就得设置成 FragmentActivity  Link

    ActivityOptions options = ActivityOptions.makeSceneTransitionAnimation(
            MainActivity.this,
            iv_click,
            getString(R.string.MainToSecond)
            );
    
  5. makeSceneTransitionAnimation(Activity activity,Pair<View, String>… sharedElements)
    效果: 用于多个元素共享

    • Pair里的view别强转成TextView, ImageView
    ActivityOptions options = ActivityOptions.makeSceneTransitionAnimation(
                           MainActivity.this,
                           Pair.create(findViewById(R.id.iv_click), getString(R.string.MainToSecond)), //这里是View, 不能是ImageView, TextView之类的
                           Pair.create(findViewById(R.id.tv_click), getString(R.string.MainToSecondText)));
                   startActivity(intent,options.toBundle());
    

动画效果

提供了5种.

添加方法

右键res, new -> Android resource directory -> transition

新建的文件根标记需要设置为<transitionSet>, 如果是<transitionManager> 会导致 <item name="android:windowSharedElementEnterTransition">@transition/change_bounds</item>不能识别

//是否允许过渡动画
<item name="android:windowContentTransitions">true</item>
//A Activity 动画效果是否显示
<item name="android:windowAllowEnterTransitionOverlap">true</item>
//B Activity 动画效果是否显示
<item name="android:windowAllowReturnTransitionOverlap">true</item>
//指定普通进入动画
<item name="android:windowEnterTransition">@android:transition/slide_bottom</item>
//指定普通退出动画
<item name="android:windowExitTransition">@android:transition/slide_bottom</item>
//自定义进入的transition动画
<item name="android:windowSharedElementEnterTransition">@transition/change_bounds</item>
//自定义退出的transition动画
<item name="android:windowSharedElementExitTransition">@transition/change_bounds</item>

兼容低版本(不挂,还是没效果)

注意: Pair类也要是V4包的

ActivityOptionsCompat optionsCompat = ActivityOptionsCompat.makeSceneTransitionAnimation(
                       MainActivity.this,
                       android.support.v4.util.Pair.create(findViewById(R.id.iv_click), getString(R.string.MainToSecond)),
                       android.support.v4.util.Pair.create(findViewById(R.id.tv_click), getString(R.string.MainToSecondText)));

参考
CSDN | 关于activity转场动画makeSceneTransitionAnimation没效果的问题的解决办法
Google | 定制操作行为转换
CSDN | 你所不知道的Activity转场动画——ActivityOptions

相关文章

  • Day14-Activity动画

    Activity动画 分为两种, overridePendingTransition ActivityOption...

  • Android回顾--(十六) 动画简析

    动画: 补间动画(Tween动画) 帧动画(Frame动画) 属性动画(Property动画) 补间动画 特点: ...

  • 在山西太原,做个二维动画需要哪些制作流程?

    二维动画有哪些类型? flash动画,课件动画,mg动画,ae动画,GIF动画,手绘动画,网页动画,企业动画,宣传...

  • Android 动画

    【Android 动画】 动画分类补间动画(Tween动画)帧动画(Frame 动画)属性动画(Property ...

  • 动画学习

    动画 分为 组动画,属性动画,渐变动画,其中属性动画包括 普通动画和关键帧动画,其他动弹动画,动画层分为 pres...

  • Android动画

    Android动画分类: 视图动画:补间动画、逐帧动画 属性动画 视图动画 补间动画 可以在xml中定义动画,然后...

  • iOS动画

    iOS动画-从UIView动画说起iOS动画-Transform和KeyFrame动画iOS动画-layout动画...

  • Android动画之视图动画

    分类 Android动画主要包括视图动画和属性动画。视图动画包括Tween动画和Frame动画。Tween动画又包...

  • Android 动画

    android动画分为三种 帧动画,视图动画(补间动画),属性动画逐帧动画 视图动画 属性动画 Window和A...

  • android动画

    动画: 分类:分为视图动画和属性动画,其中视图动画又分为补间动画和逐帧动画。补间动画又分为平移动画、缩放动画、旋转...

网友评论

      本文标题:Day14-Activity动画

      本文链接:https://www.haomeiwen.com/subject/bfvijxtx.html