zoukankan      html  css  js  c++  java
  • Android ProgressBar分析及自定义ProgressBar

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

    而能取决于是什么样式的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:Javaandroid-sdk-windowsplatformsandroid-19data esdrawable

    找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"/>

    然后里面需要放一个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里面的那棵不断生长的矢量树用的就是逐帧动画),执行耗时操作的时候调用出来,执行完毕撤销~

  • 相关阅读:
    多组件共享-vuex
    在子组件中触发事件,传值给父组件-vue
    在父组件中,直接获取子组件数据-vue
    非父子组件通过事件传值-vue
    在父组件中,传值给子组件-vue
    MVVM
    Virtual DOM-渲染函数render -vue
    duilib入门简明教程 -- VS环境配置(2) (转)
    duilib入门简明教程 -- 前言(1) (转)
    【CDockablePane】关于CDockablePane
  • 原文地址:https://www.cnblogs.com/glimpse/p/5273046.html
Copyright © 2011-2022 走看看