Android动画 超简单的6种activity进入返回动画 小白马上就可以使用

添加动画anim

新activity进入方式

默认是右往左进入动画

1、下往上推进入动画——100与-100互换即可——上往下推进入动画

in:

<?xml version="1.0" encoding="utf-8"?>

<set xmlns:android="http://schemas.android.com/apk/res/android">
    <translate
        android:duration="700"
        android:fromYDelta="100%p"
        android:toYDelta="0" />
    <alpha
        android:duration="700"
        android:fromAlpha="0.0"
        android:toAlpha="1.0" />
</set>

out:

<?xml version="1.0" encoding="utf-8"?>

<set xmlns:android="http://schemas.android.com/apk/res/android">
    <translate
        android:duration="700"
        android:fromYDelta="0"
        android:toYDelta="-100%p" />
    <alpha
        android:duration="700"
        android:fromAlpha="1.0"
        android:toAlpha="0.0" />
</set>

2、左往右进入动画

in:

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

out:

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

3、透明淡出,中间缩放进入动画

in:

<?xml version="1.0" encoding="utf-8"?><!-- android:duration="@android:integer/config_mediumAnimTime" -->
<set xmlns:android="http://schemas.android.com/apk/res/android">
    <scale
        android:duration="1000"
        android:fillAfter="false"
        android:fromXScale="0.0"
        android:fromYScale="0.0"
        android:interpolator="@android:anim/accelerate_decelerate_interpolator"
        android:pivotX="50%"
        android:pivotY="50%"
        android:toXScale="1"
        android:toYScale="1" />
</set>

out:

<?xml version="1.0" encoding="utf-8"?><!-- android:duration="@android:integer/config_mediumAnimTime" -->
<set xmlns:android="http://schemas.android.com/apk/res/android">
    <alpha
        android:duration="1000"
        android:fromAlpha="1.0"
        android:toAlpha="0" />

</set>

4、透明淡出,左上角放大进入动画

in:

<?xml version="1.0" encoding="utf-8"?><!-- android:duration="@android:integer/config_mediumAnimTime" -->
<set xmlns:android="http://schemas.android.com/apk/res/android"
    android:shareInterpolator="false">
    <scale
        android:duration="1000"
        android:fromXScale="0.0"
        android:fromYScale="0.0"
        android:interpolator="@android:anim/decelerate_interpolator"
        android:pivotX="0"
        android:pivotY="0"
        android:repeatCount="0"
        android:startOffset="0"
        android:toXScale="1.0"
        android:toYScale="1.0"></scale>

</set>

out:......

5、组合动画,旋转,缩放,移动

<?xml version="1.0" encoding="utf-8"?><!-- android:duration="@android:integer/config_mediumAnimTime" -->
<set xmlns:android="http://schemas.android.com/apk/res/android"
    android:shareInterpolator="false">
    <scale
        android:duration="2000"
        android:fromXScale="0.0"
        android:fromYScale="0.0"
        android:interpolator="@android:anim/decelerate_interpolator"
        android:pivotX="50%"
        android:pivotY="50%"
        android:toXScale="1.0"
        android:toYScale="1.0"></scale>
    <translate
        android:duration="2000"
        android:fromXDelta="120"
        android:fromYDelta="30"
        android:interpolator="@android:anim/accelerate_decelerate_interpolator"
        android:toXDelta="30"
        android:toYDelta="250" />
    <rotate
        android:duration="2000"
        android:fromDegrees="0"
        android:interpolator="@android:anim/accelerate_decelerate_interpolator"
        android:pivotX="50%"
        android:pivotY="50%"
        android:toDegrees="+355" />
</set>

6、左上角退出,外围缩放进入动画

in:

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android"
    android:interpolator="@android:anim/decelerate_interpolator">
    <alpha
        android:duration="1000"
        android:fromAlpha="0"
        android:toAlpha="1.0" />
    <scale
        android:duration="1000"
        android:fromXScale="2.0"
        android:fromYScale="2.0"
        android:pivotX="50%p"
        android:pivotY="50%p"
        android:toXScale="1.0"
        android:toYScale="1.0" />
</set>

out:

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android"
    android:interpolator="@android:anim/decelerate_interpolator"
    android:zAdjustment="top">
    <scale
        android:duration="2000"
        android:fromXScale="1.0"
        android:fromYScale="1.0"
        android:pivotX="0"
        android:pivotY="0"
        android:toXScale="0"
        android:toYScale="0" />
    <alpha
        android:duration="2000"
        android:fromAlpha="1.0"
        android:toAlpha="0" />
</set>

 

activity实现跳转动画代码

 

private Context mContext;
mContext = MainActivity.this;
 
 
  1. startView.setOnClickListener(new View.OnClickListener() {

  2. @Override

  3. public void onClick(View v) {

  4.  
  5. Intent intent = new Intent(mContext, MyTwoActivity.class);

  6. mContext.startActivity(intent);

  7.  
  8. ((Activity)mContext).overridePendingTransition(R.anim.zoom_enter,

  9. R.anim.zoom_exit);

  10.  
  11. }

  12. });

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
关于 Android 动画变黑的问题,一般是由于 Activity进入和退出动画没有设置正确导致的。下面介绍两常见的解决方式: 1. 使用 overridePendingTransition 方法设置 Activity进入和退出动画 在启动一个新的 Activity 时,可以使用 `overridePendingTransition` 方法设置它的进入和退出动画。这个方法可以在启动新的 Activity 之后立即调用,如下所示: ```java Intent intent = new Intent(this, NewActivity.class); startActivity(intent); overridePendingTransition(R.anim.slide_in_right, R.anim.slide_out_left); ``` 其中 `slide_in_right` 和 `slide_out_left` 是两个动画资源文件,分别表示新的 Activity 从右边滑入和当前 Activity 向左边滑出。 2. 在 styles.xml 文件中设置 Activity进入和退出动画 可以在 `styles.xml` 文件中为 Activity 设置进入和退出动画,如下所示: ```xml <style name="MyTheme" parent="@android:style/Theme"> <item name="android:windowAnimationStyle">@style/MyAnimation.Window</item> </style> <style name="MyAnimation.Window" parent="@android:style/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> ``` 其中 `MyTheme` 是自定义的主题,`MyAnimation.Window` 是自定义的动画样式,`@anim/slide_in_right` 和 `@anim/slide_out_left` 分别表示进入和退出动画的资源文件。 注意:在使用第二方式时,需要在 AndroidManifest.xml 文件中为对应的 Activity 指定主题,如下所示: ```xml <activity android:name=".MainActivity" android:theme="@style/MyTheme" /> ``` 以上两方式都可以解决 Android 动画变黑的问题,具体使用方式,可以根据实际情况选择。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值