Android ProgressBar分析及自定义ProgressBar

转:http://www.cnblogs.com/glimpse/p/5273046.html

rogressBar是在执行耗时操作时的一种人性化设计。分为两种形式:转圈的,能显示进度的。

而能取决于是什么样式的PregressBar,当然就是PregressBar的样式啦~

Widget.ProgressBar.Horizontal  水平进度条
Widget.ProgressBar.Small    小环形进度条
Widget.ProgressBar.Large    大环形进度条 Widget.ProgressBar.Inverse   普通大小的环形进度条 Widget.ProgressBar.Small.Inverse  小环形进度条 Widget.ProgressBar.Large.Inverse  大环形进度条

首先讲一下能够显示进度的ProgressBar.
定义带进度条的progressbar除了需要设置style以外还要设置一个最大值max,表示进度的结束值。
如下可以通过xml来设置,除此之外还可以在代码中使用setMax来设置:
复制代码
<!-- 定义一个水平进度条 -->
<ProgressBar
    android:id="@+id/bar"
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content"
    android:max="100"
    style="@android:style/Widget.ProgressBar.Horizontal"
    />
复制代码

然后在使用的时候,在进度达到不同的情况下,设置一下进度就能显示相应的变化啦~

复制代码
package org.crazyit.ui;


public class ProgressBarTest extends Activity
{
    // 该程序模拟填充长度为100的数组
    private int[] data = new int[100];
    int hasData = 0;
    // 记录ProgressBar的完成进度
    int status = 0;    
    ProgressBar bar;
    // 创建一个负责更新的进度的Handler
    Handler mHandler = new Handler()
    {
        @Override
        public void handleMessage(Message msg)
        {
            // 表明消息是由该程序发送的
            if (msg.what == 0x111)
            {
                bar.setProgress(status);//设置进度             }
        }
    };    
    @Override
    public void onCreate(Bundle savedInstanceState)
    {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        bar = (ProgressBar) findViewById(R.id.bar);
       // 启动线程来执行任务
        new Thread()
        {
            public void run()
            {
                while (status < 100)
                {
                    // 获取耗时操作的完成百分比
                    status = doWork();
                    // 发送消息
                    mHandler.sendEmptyMessage(0x111);
                }
            }
        }.start();
    }
    // 模拟一个耗时的操作
    public int doWork()
    {
        // 为数组元素赋值
        data[hasData++] = (int) (Math.random() * 100);
        try
        {
            Thread.sleep(100);
        }
        catch (InterruptedException e)
        {
            e.printStackTrace();
        }
        return hasData;
    }
}
复制代码

好吧,这些都是直接用的书里的示例代码。红色代码就是设置相应的进度啦~

代码里在线程中执行了模拟耗时操作dowork函数,当然最常用的是把dowork函数换成下载函数。

 

当然使用完毕我们并不希望再看到他,这个时候调用一下

bar.setVisibility(View.GONE);

就好啦~

 

自定义ProgressBar

当然很多情况,我们是不大会用他们原本的样式的,会自定义一下这些东西。

首先讲一下环形进度条xml源码。

<!-- 定义一个大环形进度条 -->
<ProgressBar
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content"
    style="@android:style/Widget.ProgressBar.Large"
    />

看这个样子,奥秘只能在style里面,让我们进去看看~

复制代码
<style name="Widget.ProgressBar.Large">
        <item name="android:indeterminateDrawable">@android:drawable/progress_large_white</item>
        <item name="android:minWidth">76dip</item>
        <item name="android:maxWidth">76dip</item>
        <item name="android:minHeight">76dip</item>
        <item name="android:maxHeight">76dip</item>
    </style>
复制代码

这个地方长这个毛线样,分别定义了图片资源和宽高,那么可想而知,我们要改的是图。然后再进@android :drawable/progress_large_white里面去看一下~

这个时候已经没有链接了,我们直接去sdk里找,具体位置是:D:\Java\android-sdk-windows\platforms\android-19\data\res\drawable

找progress_large_white.xml看一下。

<animated-rotate xmlns:android="http://schemas.android.com/apk/res/android"
    android:drawable="@drawable/spinner_black_76"
    android:pivotX="50%"
    android:pivotY="50%"
    android:framesCount="12"
    android:frameDuration="100" />

啊,原来是这样的~我们修改一下drawable不就得了,那来吧~

首先找一张图片放进资源文件夹里

然后写一个上面那样的animated-rotate,把android:drawable的值换成自己的图片资源。

再然后就是写一个style,把里面的android:indeterminateDrawable的值换成自己写的animated-rotate文件名。

再再然后就是在progressbar里面的style的值换成自己写的style,重新来一遍就是了~

 

 

然后再说一说水平进度条啦~

因为水平进度条有完成和没完成之分,我们自定义主要就是自定义这两边的样子~

这个你就在progressbar里面加一个progressDrawable。

复制代码
<!-- 定义一个水平进度条,并改变轨道外观 -->
<ProgressBar
    android:id="@+id/bar2"
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content"
    android:max="100"
    android:progressDrawable="@drawable/my_bar"
    style="@android:style/Widget.ProgressBar.Horizontal"/>
复制代码

然后res/drawable-mdpi目录里面需要放一个mybar.xml。

 

复制代码
<?xml version="1.0" encoding="UTF-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
    <!-- 定义轨道的背景 -->
    <item android:id="@android:id/background"
        android:drawable="@drawable/no" />
    <!-- 定义轨道上已完成部分的样式 -->
    <item android:id="@android:id/progress"
        android:drawable="@drawable/ok" />
</layer-list>
复制代码

然后你就找两个图放上去就好啦~



但是,这两种自定义只是换下背景图而已,基本的样子还是没有发生什么变化。其实我们可以做一个小动画(比如韩寒的One里面的那棵不断生长的矢量树用的就是逐帧动画),执行耗时操作的时候调用出来,执行完毕撤销~


转载于:https://my.oschina.net/Draymond/blog/1017480

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值