android activity刚打开时内部动画卡顿问题

最近遇到这个问题,一个activity中有一个imageview的旋转动画,当activity刚打开时,前几秒这个旋转的动画没有转动的过程,过了0.几秒以后直接卡到某个未知接着转.到处搜索都是说activity出现时的过渡动画的问题,感觉人类语言不足以精简的表达这种事情ORZ.

Google后找到了这个文章这个文章,大致就是说:

It’s important to note that the start() method called on the AnimationDrawable cannot be called during the onCreate() method of your Activity, because the AnimationDrawable is not yet fully attached to the window.

大致就是说将startAnimation放到onWindowFocusChanged中就好了,然后试了试因为视觉差还是感觉卡顿,于是直接将动画delay了,确实有效.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: Android Activity跳转动画是指在Activity之间切换,为了增强用户体验而添加的动画效果。常见的跳转动画有淡入淡出、滑动、旋转等。可以通过在代码中设置Activity的进入和退出动画来实现。例如: 1. 淡入淡出动画 在res/anim目录下创建fade_in.xml和fade_out.xml两个文件,分别表示Activity进入和退出动画效果。 fade_in.xml: ``` <alpha xmlns:android="http://schemas.android.com/apk/res/android" android:duration="500" android:fromAlpha="0.0" android:toAlpha="1.0" /> ``` fade_out.xml: ``` <alpha xmlns:android="http://schemas.android.com/apk/res/android" android:duration="500" android:fromAlpha="1.0" android:toAlpha="0.0" /> ``` 在代码中设置Activity的进入和退出动画: ``` startActivity(intent); overridePendingTransition(R.anim.fade_in, R.anim.fade_out); ``` 2. 滑动动画 在res/anim目录下创建slide_in.xml和slide_out.xml两个文件,分别表示Activity进入和退出动画效果。 slide_in.xml: ``` <set xmlns:android="http://schemas.android.com/apk/res/android"> <translate android:fromXDelta="100%p" android:toXDelta="0" android:duration="500"/> <alpha android:fromAlpha="0.0" android:toAlpha="1.0" android:duration="500" /> </set> ``` slide_out.xml: ``` <set xmlns:android="http://schemas.android.com/apk/res/android"> <translate android:fromXDelta="0" android:toXDelta="-100%p" android:duration="500"/> <alpha android:fromAlpha="1.0" android:toAlpha="0.0" android:duration="500" /> </set> ``` 在代码中设置Activity的进入和退出动画: ``` startActivity(intent); overridePendingTransition(R.anim.slide_in, R.anim.slide_out); ``` 以上是两种常见的Activity跳转动画,开发者可以根据需要自定义动画效果。 ### 回答2: Android平台的Activity是应用程序中最重要的部分之一。当我们需要在应用程序中切换不同的Activity,我们可以使用跳转动画来创建更加平滑和丰富的用户交互体验。本文将重点介绍如何在Android应用程序中实现Activity的跳转动画。 1. 系统默认动画 Android系统提供了一些默认的Activity跳转动画,包括从右往左滑动、从左往右滑动、从上往下滑动、从下往上滑动等。我们可以在Intent中使用setFlags方法来设置跳转动画,例如: intent.setFlags(Intent.FLAG_ACTIVITY_NO_ANIMATION); startActivity(intent); overridePendingTransition(R.anim.slide_right_in, R.anim.slide_left_out); 2. 自定义动画 除了系统默认动画,我们还可以根据自己的需求来创建自定义的Activity跳转动画Android系统提供了一些动画资源文件,包括translate、scale、rotate和alpha四种类型。我们可以通过在res目录下的anim文件夹中创建xml文件来定义自定义动画,例如: <?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android" android:fillAfter="true"> <translate android:fromXDelta="0%" android:toXDelta="100%" android:duration="500"/> </set> 我们在代码中使用以下方法来启动Activity和设置动画: Intent intent = new Intent(MainActivity.this, SecondActivity.class); startActivity(intent); overridePendingTransition(R.anim.slide_in, R.anim.slide_out); 其中,slide_in.xml和slide_out.xml分别是进入和退出Activity动画,可以根据自己的需要来定义。 总结:以上是Android中实现Activity跳转动画的方法。在实践中,我们可以根据实际需求来选择系统默认动画或自定义动画,以提升用户体验。在创建自定义动画,需要注意动画类型的选择和动画长的设置,以达到最佳效果。 ### 回答3: AndroidActivity跳转动画是指系统在跳转Activity所播放的动画效果。Android提供了许多内置的跳转动画效果,例如淡入淡出、左/右滑入、翻转、放缩等等。除了这些内置的动画效果,我们还可以自定义Activity跳转动画,以满足个性化需求。 在实现Activity跳转动画,我们通常需要在startActivity()或finish()方法中添加相应的动画参数。例如,当从Activity A跳转到Activity B,我们可以在startActivity()方法中添加以下代码: ``` startActivity(intent); overridePendingTransition(R.anim.slide_in_right, R.anim.slide_out_left); ``` 其中,R.anim.slide_in_right和R.anim.slide_out_left是我们自定义的两个动画效果,表示Activity B从右侧滑入,Activity A从左侧滑出。这两个动画效果需要我们在res文件夹下创建anim文件夹,并在该文件夹下添加相应的XML文件。 slide_in_right.xml的代码如下: ``` <set xmlns:android="http://schemas.android.com/apk/res/android" android:fillAfter="true"> <translate android:fromXDelta="100%p" android:toXDelta="0" android:duration="500"/> <alpha android:fromAlpha="0.0" android:toAlpha="1.0" android:duration="500" /> </set> ``` slide_out_left.xml的代码如下: ``` <set xmlns:android="http://schemas.android.com/apk/res/android" android:fillAfter="true"> <translate android:fromXDelta="0" android:toXDelta="-100%p" android:duration="500"/> <alpha android:fromAlpha="1.0" android:toAlpha="0.0" android:duration="500" /> </set> ``` 可以看到,slide_in_right.xml描述了Activity B从右侧进入的动画效果,其中包括了平移和透明度渐变两个动画效果。而slide_out_left.xml描述了Activity A从左侧离开的动画效果,同样包括了平移和透明度渐变两个动画效果。 除了基本的平移、透明度渐变效果之外,我们还可以使用缩放、旋转等复杂的动画效果来实现更丰富的跳转动画效果。需要注意的是,动画效果的实现需要考虑到用户体验和性能问题,避免出现卡顿或者过多的动画效果影响用户体验。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值