app直播源码,自定义两种Activity切换动画实现

大标 2022年3月16日14:48:18
评论
19

app直播源码,自定义两种Activity切换动画实现

法一:指定某个Activity的切换动画

设置打开新Activity时展示的动画

在调用startActivity之后调用overridePendingTransition

 


findViewById(R.id.btn).setOnClickListener(v -> {
    startActivity(new Intent(this, MainActivity2.class));
    // 下一个activity的进入动画,当前activity的退出动画
overridePendingTransition(R.anim.slide_in_right, R.anim.slide_out_left);
});

设置关闭当前Activity时展示的动画

在调用finish()的之super.finish();后调用overridePendingTransition

 


@Override
public void finish() {
    super.finish();
    // 下一个的进入,自己的退出
    overridePendingTransition(R.anim.slide_in_left, R.anim.slide_out_right);
}

TIPS:自定义动画会覆盖全局动画

法二:定义全局动画

在res/values/styles.xml文件中新建style:

 


<style name=\"CustomActivityAnimation\" parent=\"android:Animation.Activity\">
    <item name=\"android:activityOpenEnterAnimation\">@anim/slide_in_right</item>
    <item name=\"android:activityOpenExitAnimation\">@anim/slide_out_left</item>
    <item name=\"android:activityCloseEnterAnimation\">@anim/slide_in_left</item>
    <item name=\"android:activityCloseExitAnimation\">@anim/slide_out_right</item>
</style>

在应用的 Theme(主题) 中应用上面新建的CustomActivityAnimation:

 


<style name=\"AppTheme\" parent=\"Theme.AppCompat.Light.DarkActionBar\">
    <!--其他省略...-->
    <item name=\"android:windowAnimationStyle\">@style/CustomActivityAnimation</item>
</style>

动画文件

在res/anim文件夹下面新建动画文件:

slide_in_right.xml

 

<?xml version=\"1.0\" encoding=\"utf-8\"?>
<set xmlns:android=\"http://schemas.android.com/apk/res/android\">
    <translate
        android:duration=\"@android:integer/config_mediumAnimTime\"
        android:fromXDelta=\"100%p\"
        android:toXDelta=\"0\" />
</set>

slide_out_left.xml

 


<?xml version=\"1.0\" encoding=\"utf-8\"?>
<set xmlns:android=\"http://schemas.android.com/apk/res/android\">
    <translate
        android:duration=\"@android:integer/config_mediumAnimTime\"
        android:fromXDelta=\"0\"
        android:toXDelta=\"-100%p\" />
</set>

slide_in_left.xml

 


<?xml version=\"1.0\" encoding=\"utf-8\"?>
<set xmlns:android=\"http://schemas.android.com/apk/res/android\">
    <translate
        android:duration=\"@android:integer/config_mediumAnimTime\"
        android:fromXDelta=\"-100%p\"
        android:toXDelta=\"0\" />
</set>

slide_out_right.xml

 


<?xml version=\"1.0\" encoding=\"utf-8\"?>
<set xmlns:android=\"http://schemas.android.com/apk/res/android\">
    <translate
        android:duration=\"@android:integer/config_mediumAnimTime\"
        android:fromXDelta=\"0\"
        android:toXDelta=\"100%p\" />
</set>

以上就是 app直播源码,自定义两种Activity切换动画实现,更多内容欢迎关注之后的文章

 

  • 我的微信
  • 微信扫一扫
  • weinxin
  • 我的微信公众号
  • 微信扫一扫
  • weinxin
大标
  • 本文由 发表于 2022年3月16日14:48:18
  • 转载请务必保留本文链接:https://www.tanhuibiao.com/script/qita/4665.html
匿名

发表评论

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: