安卓属性动画的总结

做了一个月的安卓属性动画,要过是对一张图片进行从一点缓缓展开,然后在图片上显示数字,显示一段时间之后数字消失,消失后图片也紧跟着缓缓消失的效果。

  1. 刚开始用的Canvas进行对图片画实现动画的效果,通过Matrix来手动的调节图片放大+倾斜的效果近似的模拟展开的效果,后来发现如果用Canvas.drawBitmap的方法会出现卡顿的现象,因为Matrix调节的像素是手动调节的,所以会出现卡顿的现象。
  2. 后来用ValueAnimator来实现动画的效果,流畅度有了很好的提升,用 valueAnimator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
    @Override
    public void onAnimationUpdate(ValueAnimator animation) {
    }
    }
    这个方法实现的效果还好,通过控制x、y也可以实现类抛物线的运行轨迹,也可以设置方向上的加速度。但是还是用Matrix做模拟的放大+倾斜实现,但是感觉不流畅
  3. 针对安卓的轨迹动画,我有用了贝塞尔曲线的方式,先通过贝塞尔曲线画出一条图片运行的轨迹,然后通过PathMeasure来实现图片的寻路径运行,实现了图片的运行轨迹的效果
  4. 针对最后的类似于苹果电脑上文件收放的流畅效果,借鉴了
    http://blog.csdn.net/leehong2005/article/details/9127095这个网站上的效果,图片变得更加流畅了,但是我们是很小的动画,运行的速度很快,老大说没必要这么麻烦,直接用缩小+倾斜实现图片的出入,瞬间被石化有木有
  5. 其实后来想想如果想实现更多的效果,就去把OpenGL看看吧,那个实现翻页的效果很流畅,如果用到这个动画上肯定比4中的流畅的多
  6. 最终还是用了ValueAnimator实现了这个小动画。。。但是实现这个用了近两周的时间,实现了四五种不同的动画效果,当然老大让用属性动画而不让用手动Canvas去画Bitmap,因为属性动画性能会更好,能自动实现硬加速。
  7. 欢迎大家来拍砖,一起讨论属性动画、OpenGL等方面的知识。
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值