美文网首页
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动画

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