drawable文件夹的问题+使用drowable定义动画

本文介绍了如何解决Android项目中因图片资源放置不当导致的Resources$NotFoundException错误,并详细讲解了使用AnimationDrawable实现动画效果的方法。

1.在Android Studio中,有一个drawable文件夹,但是它里面是又多了一个v21文件夹,这个v21文件夹里存放的是api21以上用到的资源,而api21一下则不会调用这里的资源。

今天出现的情况就是这样,将图片复制到项目内的时候,忽略了这个问题,它被放在了v21文件夹内,编译的时候没有任何问题,但是运行之后,出现Resources$NotFoundException的错误。由于是xml定义的动画,所以开始以为是xml的问题,检查几遍也没有发现问题,后来才明白是问题出在v21。再见

2.AnimationDrawable

这个可以使用多张图片组合来实现动画效果,如文件下载,上传都是使用这个来实现的。

文件上传图片共有6张

使用xml进行配置组合:animation.xml

<?xml version="1.0" encoding="utf-8"?>
<animation-list xmlns:android="http://schemas.android.com/apk/res/android"
    android:oneshot="false">
    <item
        android:drawable="@drawable/stat_sys_upload_anim0"
        android:duration="200" />
    <item
        android:drawable="@drawable/stat_sys_upload_anim1"
        android:duration="200" />
    <item
        android:drawable="@drawable/stat_sys_upload_anim2"
        android:duration="200" />
    <item
        android:drawable="@drawable/stat_sys_upload_anim3"
        android:duration="200" />
    <item
        android:drawable="@drawable/stat_sys_upload_anim4"
        android:duration="200" />
    <item
        android:drawable="@drawable/stat_sys_upload_anim5"
        android:duration="200" />
</animation-list>

然后将其作为背景设置到ImageView控件上:

uploadImage.setBackgroundResource(R.drawable.animation);

获取动画
        animationDrawable = (AnimationDrawable) uploadImage.getBackground();
之后就可以控制动画的开始与停止了:
animationDrawable.start();
<pre style="background-color:#ffffff;color:#000000;font-family:'Consolas';font-size:13.5pt;"><pre style="background-color:#ffffff;color:#000000;font-family:'Consolas';font-size:13.5pt;"><pre name="code" class="html">animationDrawable.stop();







### 在 Android 中直接使用放置在 res/drawable 文件夹中的 GIF 动图 在 Android 项目中,如果需要直接使用存放在 `res/drawable` 文件夹中的 GIF 动图(例如名为 `yinfu.gif` 的文件),可以通过以下方法实现。Android 原生的 `ImageView` 并不支持直接播放 GIF 动图,因此需要借助第三方库来完成此功能。 #### 使用 Glide 库加载和播放 GIF 动图 Glide 是一个强大的图片加载库,支持加载和播放 GIF 动图。以下是具体实现方法: 1. **添加 Glide 依赖** 在项目的 `build.gradle` 文件中添加 Glide 的依赖项。 ```gradle dependencies { implementation 'com.github.bumptech.glide:glide:4.15.1' annotationProcessor 'com.github.bumptech.glide:compiler:4.15.1' } ``` 2. **在布局文件定义 ImageView** 在 XML 布局文件中,定义一个 `ImageView` 来显示 GIF 动图。 ```xml <ImageView android:id="@+id/imageView" android:layout_width="wrap_content" android:layout_height="wrap_content" /> ``` 3. **通过代码加载 GIF 动图** 在 Activity 或 Fragment 中,使用 Glide 加载 `res/drawable` 文件夹中的 GIF 动图。 ```java import com.bumptech.glide.Glide; public class MainActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); ImageView imageView = findViewById(R.id.imageView); Glide.with(this) .load(R.drawable.yinfu) // 直接加载 res/drawable 中的 GIF 资源 .into(imageView); } } ``` 上述代码中,`R.drawable.yinfu` 指向 `res/drawable` 文件夹中的 `yinfu.gif` 文件[^2]。 #### 使用 Picasso 库加载和播放 GIF 动图 Picasso 是另一个常用的图片加载库,同样支持加载和播放 GIF 动图。以下是使用 Picasso 的方法: 1. **添加 Picasso 依赖** 在项目的 `build.gradle` 文件中添加 Picasso 的依赖项。 ```gradle dependencies { implementation 'com.squareup.picasso:picasso:2.8' } ``` 2. **通过代码加载 GIF 动图** 在 Activity 或 Fragment 中,使用 Picasso 加载 `res/drawable` 文件夹中的 GIF 动图。 ```java import com.squareup.picasso.Picasso; public class MainActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); ImageView imageView = findViewById(R.id.imageView); Picasso.get() .load(R.drawable.yinfu) // 直接加载 res/drawable 中的 GIF 资源 .into(imageView); } } ``` 上述代码中,`R.drawable.yinfu` 指向 `res/drawable` 文件夹中的 `yinfu.gif` 文件[^3]。 #### 注意事项 - 确保 `yinfu.gif` 文件已正确放置在 `res/drawable` 文件夹中。 - 如果 GIF 文件较大,可能会导致内存占用过高,建议优化 GIF 文件的大小和分辨率。 - 使用第三方库时,请确保遵循其许可证要求。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值