利用animation轻松写出动态加载框


首先看一下效果图:

我们要实现的就是图中动态旋转的一个加载样式图,图片资源均来自互联网,下面会附上源码。

实现该效果有很多种办法,本次要记录的时使用animation样式的progressbar来实现,既简单又美观。

首先要创建一个anim的样式文件loading.xml,单独放在anim文件夹下

<?xml version="1.0" encoding="UTF-8"?>
<animation-list android:oneshot="false"
  xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:duration="200" android:drawable="@drawable/refresh1" />
    <item android:duration="200" android:drawable="@drawable/refresh2" />
    <item android:duration="200" android:drawable="@drawable/refresh3" />
    <item android:duration="200" android:drawable="@drawable/refresh4" />
    <item android:duration="200" android:drawable="@drawable/refresh5" />
    <item android:duration="200" android:drawable="@drawable/refresh6" />
    <item android:duration="200" android:drawable="@drawable/refresh7" />
    <item android:duration="200" android:drawable="@drawable/refresh8" />
</animation-list>

refresh1-8代表动态切换的八张图片,每张停留的时间设为200,这个单位难道时毫秒?应该是。

xml文件建立好,要在styles文件中利用它。创建styles.xml文件,内容如下:

<?xml version="1.0" encoding="UTF-8"?>
<resources>
    <style name="qZoneListProgressStyle" parent="@android:style/Widget.ProgressBar.Small">
        <item name="android:indeterminateDrawable">@anim/loading</item>
    </style>
</resources>

接下来只要在layout文件中添加一个progressba控件,然后style设置为我们刚刚写的style就好了。

<?xml version="1.0" encoding="UTF-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:gravity="center"
    android:orientation="horizontal"
    android:id="@+id/LinearLayoutloadingfooter"
    android:background="#ffebf8ff"
    android:layout_width="fill_parent"
    android:layout_height="60.0dip"
    >
    
    <ProgressBar
        android:id="@+id/footLoading"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        style="@style/qZoneListProgressStyle" />
    
    <TextView
        android:textColor="@color/black"
        android:id="@+id/loading"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text ="@string/loading"
        />
</LinearLayout>

如果想要大一点的progressbar,首先要把那8张图片做的大一些,然后修改style中的内容,如下:

<style name="netdiskListProgressStyle" parent="@android:style/Widget.ProgressBar.Large">
        <item name="android:indeterminateDrawable">@anim/loading</item>
    </style>

最后附上源码:



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值