参考博客 kirk_wang 参考博客园 S丶black 参考简书 DakerYi
kirk_wang的帧动画写在anim里面 我试了试写不出来。。后来看到了S丶black的写法后试着把文件写入drawable里成功
我又试着用kirk_wang的activity的代码运行了下背景图和动画重叠了。。。最后用DakerYi的方法把
image.getBackground();
改为
image.getDrawable();
经验+1
1、帧动画的特性:
-
a. 用于生成连续的Gif效果图。
-
b. DrawableAnimation也是指此动画
2、帧动画的优缺点:
- 缺点:效果单一,逐帧播放需要很多图片,占用控件较大
- 优点:制作简单
3、帧动画的实现:
帧动画实现方法很简单,完全是图片的叠加。原理和 gif 动画一样,因为每一帧过的速度太快,眼睛来不及反应所以我们觉得是动画
而且它可以任意组合动画,组合动画可以一次进行,也可以同时进行,达到了更加炫酷的效果
下面就来看看在代码中如何让使用
准备几张帧动画的图片
然后在drawable里新建xml文件 我这里加了20张图 有点长 帧动画的缺点也很明显 就是太麻烦了
oneshot:是否只播放一次 (true是播放一遍 ,false是无限轮播)
drawable:一帧引用的图片
duration:一帧播放的时间
<?xml version="1.0" encoding="utf-8"?>
<animation-list xmlns:android="http://schemas.android.com/apk/res/android"
android:oneshot="true">
<item
android:drawable="@mipmap/push_down_1"
android:duration="50" />
<item
android:drawable="@mipmap/push_down_2"
android:duration="50" />
<item
android:drawable="@mipmap/push_down_3"
android:duration="50" />
<item
android:drawable="@mipmap/push_down_4"
android:duration="50" />
<item
android:drawable="@mipmap/push_down_5"
android:duration="50" />
<item
android:drawable="@mipmap/push_down_6"
android:duration="50" />
<item
android:drawable="@mipmap/push_down_7"
android:duration="50" />
<item
android:drawable="@mipmap/push_down_8"
android:duration="50" />
<item
android:drawable="@mipmap/push_down_9"
android:duration="50" />
<item
android:drawable="@mipmap/push_down_10"
android:duration="50" />
<item
android:drawable="@mipmap/push_up_1"
android:duration="100" />
<item
android:drawable="@mipmap/push_up_2"
android:duration="100" />
<item
android:drawable="@mipmap/push_up_3"
android:duration="100" />
<item
android:drawable="@mipmap/push_up_4"
android:duration="100" />
<item
android:drawable="@mipmap/push_up_5"
android:duration="100" />
<item
android:drawable="@mipmap/push_up_6"
android:duration="100" />
<item
android:drawable="@mipmap/push_up_7"
android:duration="100" />
<item
android:drawable="@mipmap/push_up_8"
android:duration="100" />
<item
android:drawable="@mipmap/push_up_9"
android:duration="100" />
<item
android:drawable="@mipmap/push_up_10"
android:duration="100" />
</animation-list>
acticity里面的布局是一个button按钮控制播放 一个imageview用来放动画
<Button
android:id="@+id/mStart"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="start" />
<ImageView
android:id="@+id/frame_image"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:src="@mipmap/push_down_1" />
开始播放的方法
//开始
public void startFrame(View view) {
frame_image.setBackgroundResource(R.drawable.anim_frame);
AnimationDrawable anim = (AnimationDrawable) frame_image.getDrawable();
anim.start();
}
停止的方法
//停止
public void stopFrame(View view) {
AnimationDrawable anim = (AnimationDrawable) frame_image.getDrawable();
if (anim.isRunning()) { //如果正在运行,就停止
anim.stop();
}
}
最后调用
@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.mStart:
startFrame(v);
break;
}
}
为了怕我以后忘记了再来看还是想不起来 或者写完报错 简直就是手把手教一步步扶着走啊 哎哎·