首页 > 其他 > 详细

ProgressBar样式总结与自动填充方法(代码)

时间:2014-06-26 12:13:33      阅读:420      评论:0      收藏:0      [点我收藏+]

有时候开发的时候需要用一个进度条告知用户目前正在运行一个耗时操作,但是并不需要明确知道某个value来setProgress,所以就可以自定义一个时间和进度让进度条自动运行了。

下面是代码:

 Handler mHandler=new Handler(){

        @Override
        public void handleMessage(Message msg) {
           
            p.setProgress(msg.what);
            mHandler.post(updateThread);//实现连续过程
        }
        
    };
    Runnable updateThread=new Runnable() {
        int i=0;
        @Override
        public void run() {
           
            Message m=Message.obtain();
            if(i<70){
                i=i+2;
            }
           
               m.what=i;
                try {
                 Thread.sleep(1);//间隔时间
             } catch (InterruptedException e) {
                 
                 e.printStackTrace();
             }
                mHandler.sendMessage(m);
                if(i==70)
                {
                   mHandler.removeCallbacks(updateThread);
return;//退出
                }
            }
        }
    ;



普通圆形ProgressBar该类型进度条也就是一个表示运转的过程,例如发送短信,连接网络等等,表示一个过程正在执行中。一般只要在XML布局中定义就可以了。

<progressBar android:id="@+id/widget43"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"   
      android:layout_gravity="center_vertical">
</ProgressBar>

此时,没有设置它的风格,那么它就是圆形的,一直会旋转的进度条。
各大小样式圆形ProgressBar
超大号圆形ProgressBar

此时,给设置一个style风格属性后,该ProgressBar就有了一个风格,这里大号ProgressBar的风格是:

style="?android:attr/progressBarStyleLarge"

完整XML定义是:

<progressBar android:id="@+id/widget196"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      style="?android:attr/progressBarStyleLarge">
</ProgressBar>

小号圆形ProgressBar
小号ProgressBar对应的风格是:

style="?android:attr/progressBarStyleSmall"

完整XML定义是:

<progressBar android:id="@+id/widget108"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      style="?android:attr/progressBarStyleSmall">
</ProgressBar>

标题型圆形ProgressBar
标题型ProgressBar对应的风格是:

style="?android:attr/progressBarStyleSmallTitle"

完整XML定义是:

<progressBar android:id="@+id/widget110"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    style="?android:attr/progressBarStyleSmallTitle">
</ProgressBar>

代码中实现:

@Override
    protected void onCreate(Bundle savedInstanceState) {
        // TODO Auto-generated method stub
        super.onCreate(savedInstanceState);
        requestWindowFeature(Window.FEATURE_INDETERMINATE_PROGRESS);
        //请求窗口特色风格,这里设置成不明确的进度风格
        setContentView(R.layout.second);
        setProgressBarIndeterminateVisibility(true);
        //设置标题栏中的不明确的进度条是否可以显示
    }

长形进度条
布局中的长形进度条

首先在XML进行布局
<progressBar android:id="@+id/progressbar_updown"
        android:layout_width="200dp"
        android:layout_height="wrap_content"
        style="?android:attr/progressBarStyleHorizontal"
        android:layout_gravity="center_vertical"
        android:max="100"
        android:progress="50"
        android:secondaryProgress="70"    >

讲解:

style="?android:attr/progressBarStyleHorizontal"    设置风格为长形 
android:max="100"    最大进度值为100
android:progress="50"   初始化的进度值
android:secondaryProgress="70"  初始化的底层第二个进度值 
android:layout_gravity="center_vertical"    垂直居中

代码中运用

private ProgressBar myProgressBar;
//定义ProgressBar
myProgressBar = (ProgressBar) findViewById(R.id.progressbar_updown);
//ProgressBar通过ID来从XML中获取
myProgressBar.incrementProgressBy(5);
//ProgressBar进度值增加5
myProgressBar.incrementProgressBy(-5);
//ProgressBar进度值减少5
myProgressBar.incrementSecondaryProgressBy(5);
//ProgressBar背后的第二个进度条 进度值增加5
myProgressBar.incrementSecondaryProgressBy(-5);
//ProgressBar背后的第二个进度条 进度值减少5

页面标题中的长形进度条
代码实现:
①先设置一下窗口风格特性

requestWindowFeature(Window.FEATURE_PROGRESS);
//请求一个窗口进度条特性风格
setContentView(R.layout.main);
setProgressBarVisibility(true);
//设置进度条可视

②然后设置进度值

setProgress(myProgressBar.getProgress() * 100);
//设置标题栏中前景的一个进度条进度值
setSecondaryProgress(myProgressBar.getSecondaryProgress() * 100);
//设置标题栏中后面的一个进度条进度值
//ProgressBar.getSecondaryProgress() 是用来获取其他进度条的进度值


ProgressBar样式总结与自动填充方法(代码),布布扣,bubuko.com

ProgressBar样式总结与自动填充方法(代码)

原文:http://blog.csdn.net/zpf8861/article/details/34798195

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!