Android各种动画效果,无动画,不精彩:smile::smile::smile:
闪屏页 | 引导页 | 小红书 |
---|---|---|
汽车之家 | 电报(Telegram) | 京东到家 |
---|---|---|
图片浏览 | 微知 | 翻译君 |
---|---|---|
一帧一帧进行播放,它的原理与Gif类似,按序播放一组预先定义好的图片序列,如:
<?xml version="1.0" encoding="utf-8"?>
<animation-list android:oneshot="false" xmlns:android="http://schemas.android.com/apk/res/android">
<item android:duration="100" android:drawable="@drawable/loading01" />
<item android:duration="100" android:drawable="@drawable/loading02" />
<item android:duration="100" android:drawable="@drawable/loading03" />
<item android:duration="100" android:drawable="@drawable/loading04" />
<item android:duration="100" android:drawable="@drawable/loading05" />
<item android:duration="100" android:drawable="@drawable/loading06" />
<item android:duration="100" android:drawable="@drawable/loading07" />
<item android:duration="100" android:drawable="@drawable/loading08" />
<item android:duration="100" android:drawable="@drawable/loading09" />
<item android:duration="100" android:drawable="@drawable/loading10" />
<item android:duration="100" android:drawable="@drawable/loading11" />
<item android:duration="100" android:drawable="@drawable/loading12" />
</animation-list>
动画类型 | XML配置方式 | Java代码实现方式 |
---|---|---|
渐变透明度动画 | alpha | AlphaAnimation |
缩放动画 | scale | ScaleAnimation |
旋转动画 | rotate | RotateAnimation |
平移动画 | translate | TranslateAnimation |
直接更改View 的属性来实现的动画。 工作原理:在一定时间间隔内,通过不断调用set方法对值进行改变,并不断将该值赋给对象的属性,从而实现该对象在该属性上的动画效果
Google在Android 5.0之后推出的一种动画效果,就是以某种方式从一个场景以动画的形式过渡到另一个场景,可以参考Material-Animations
Lottie 是 Airbnb推出的一套跨平台的动画完整解决方案,它能够帮助开发者直接加载json格式的文件在 iOS、Android 和 React Native之上,实现 100% 与设计稿相同的动画效果,而无需关心中间的实现细节。设计师只需要使用 After Effectes 设计出动画之后,通过使用 Lottie 提供的Bodymovin插件将设计好的动画导出成json格式的文件交付给开发即可完成。 Lottie网站 lottie-android
IM软件Telegram 推出的新的Sticker贴纸格式,这个全新的 Sticker 贴纸格式为 .tgs,其实就是基于lottie json文件改造而来的一种格式
GIF(Graphics Interchange Format)是由CompuServe公司开发的一种图像文件格式,可以将多幅图像保存到一个图像文件,展示的时候将多幅图像数据逐帧读出并显示到屏幕上,从而形成动画效果。在Android中播放GIF通常有以下几种方式:
使用Android SDK中自带的android.graphics.Movie类(已过时)- 使用Glide,fresco等图片加载类库,Glide支持加载本地和网络上的GIF图片
- 使用giflib类库在native层解码GIF,使用FrameSequenceDrawable的双缓冲机制进行绘制展示GIF中的每一帧图像
- 使用android-gif-drawable类库,其底层也是使用giflib进行GIF解码