Android(java)学习笔记130:ProgressBar使用的

首先我们看例程如下:

1.main.xml文件如下:

 1 <?xml version="1.0" encoding="utf-8"?>
 2 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 3     android:orientation="vertical"
 4     android:layout_width="fill_parent"
 5     android:layout_height="fill_parent"
 6     >
 7          <TextView
 8               android:layout_width="wrap_content"
 9            android:layout_height="wrap_content"
10            android:text="默认进度条:"
11            />
12       <ProgressBar
13            android:layout_width="wrap_content"
14            android:layout_height="wrap_content"
15            android:text="progress1" 16                 //没有设置style,默认样式,中度旋转的圆形进度条
17          />
18        <TextView
19               android:layout_width="wrap_content"
20            android:layout_height="wrap_content"
21            android:text="小圆形进度条:"
22            />
23       <ProgressBar
24           android:layout_width="wrap_content"
25           android:layout_height="wrap_content"
26           android:text="progress3"
27           style="?android:attr/progressBarStyleSmall"
28           />
29       <TextView
30               android:layout_width="wrap_content"
31            android:layout_height="wrap_content"
32            android:text="大圆形进度条:"
33            android:layout_gravity="center_vertical"
34            />
35       <ProgressBar
36           android:layout_width="wrap_content"
37           android:layout_height="wrap_content"
38           android:text="progress3"
39           style="?android:attr/progressBarStyleLarge"
40           />
41       <TextView
42               android:layout_width="wrap_content"
43            android:layout_height="wrap_content"
44            android:text="条形进度条:"
45            android:id="@+id/tv"
46            />
47       <ProgressBar
48            android:layout_width="fill_parent"
49          android:layout_height="wrap_content"
50          android:text="progress2"
51          android:id="@+id/porb"
52           style="?android:attr/progressBarStyleHorizontal"
53           android:max="100"
54           android:progress="50"
55           android:secondaryProgress="70"
56           />
57 </LinearLayout>

(2)接下来是MainActivity.java文件:

 1 package com.progressbar;
 2
 3 import android.app.Activity;
 4 import android.os.Bundle;
 5 import android.widget.ProgressBar;
 6 //使用Runnable接口
 7 public class MainActivity extends Activity implements Runnable {
 8     private Thread th ;            //声明一条线程
 9     private ProgressBar pb ;     //声明一个进度条对象
10     private boolean stateChage; //标识进度值最大最小的状态
11     @Override
12     public void onCreate(Bundle savedInstanceState) {
13         super.onCreate(savedInstanceState);
14         setContentView(R.layout.main);
15         //实例进度条对象
16         pb = (ProgressBar)findViewById(R.id.porb);
17         th = new Thread(this);//实例线程对象,当前MainActivity实现了Runnable接口,这样MainActivity本身可以作为参数实例化Thread()对象
18         th.start();//启动线程
19     }
20
21     @Override
22     public void run() {//实现Runnable接口抽象函数
23         while(true){
24             int current = pb.getProgress();//得到当前进度值
25             int currentMax = pb.getMax();//得到进度条的最大进度值
26             int secCurrent = pb.getSecondaryProgress();//得到底层当前进度值
27             //以下代码实现进度值越来越大,越来越小的一个动态效果
28             if(stateChage==false){
29                 if(current>=currentMax){
30                     stateChage=true;
31                 }else{
32                     //设置进度值
33                     pb.setProgress(current+1);
34                     //设置底层进度值
35                     pb.setSecondaryProgress(current+1);
36                 }
37             }else{
38                 if(current<=0){
39                     stateChage=false;
40                 }else{
41                     pb.setProgress(current-1);
42                     pb.setSecondaryProgress(current-1);
43                 }
44             }// 设置长方形进度条进度变大和变小的速率快慢
45             try {
46                 Thread.sleep(50);
47             } catch (InterruptedException e) {
48                 // TODO Auto-generated catch block
49                 e.printStackTrace();
50             }
51         }
52     }
53 }

总结:

1:Android的ProgressBar样式

style="?android:attr/progressBarStyleHorizontal"  长形进度条

style="?android:attr/progressBarStyleLarge"   超大号圆形ProgressBar
style="?android:attr/progressBarStyleLargeInverse"  超大号圆形ProgressBar,Inverse反向转向的
style="?android:attr/progressBarStyleSmall" 小号圆形ProgressBar

style="?android:attr/progressBarStyleSmallTitle" 标题型圆形ProgressBar

等等还有很多

2.setProgress和setSecondaryProgress区别

这么说你肯定明白:网络视频加载的时候有个播放进度和缓冲进度,播放进度一般可以用setProgerss来显示,而setSecondaryProgress就是用来显示缓冲进度的,同样的360的雷神引擎也是一样,setProgress是文件写入本地进度,setSecondaryProgress就是文件加载进度。还不明就自己写一个Demo测试一遍。写一个把复制文件的程序,setProgress表示往流里面读数据,setSecondaryProgerss表示从流里面输出数据
				
时间: 2024-10-17 14:58:08

Android(java)学习笔记130:ProgressBar使用的的相关文章

Android学习笔记_76_Android ProgressBar 进度条

android 进度条的样式  例1:(默认样式(中等圆形))Xml代码 <ProgressBar      android:id="@+id/progressBar1"     android:layout_width="wrap_content"      android:layout_height="wrap_content"      /> 例2:(超大圆形)Xml代码 <ProgressBar      android

java/android 设计模式学习笔记(14)---外观模式

这篇博客来介绍外观模式(Facade Pattern),外观模式也称为门面模式,它在开发过程中运用频率非常高,尤其是第三方 SDK 基本很大概率都会使用外观模式.通过一个外观类使得整个子系统只有一个统一的高层的接口,这样能够降低用户的使用成本,也对用户屏蔽了很多实现细节.当然,在我们的开发过程中,外观模式也是我们封装 API 的常用手段,例如网络模块.ImageLoader 模块等.其实我们在开发过程中可能已经使用过很多次外观模式,只是没有从理论层面去了解它. 转载请注明出处:http://bl

java/android 设计模式学习笔记(10)---建造者模式

这篇博客我们来介绍一下建造者模式(Builder Pattern),建造者模式又被称为生成器模式,是创造性模式之一,与工厂方法模式和抽象工厂模式不同,后两者的目的是为了实现多态性,而 Builder 模式的目的则是为了将对象的构建与展示分离.Builder 模式是一步一步创建一个复杂对象的创建型模式,它允许用户在不知道内部构建细节的情况下,可以更精细地控制对象的构造流程.一个复杂的对象有大量的组成部分,比如汽车它有车轮.方向盘.发动机.以及各种各样的小零件,要将这些部件装配成一辆汽车,这个装配过

java/android 设计模式学习笔记(一)---单例模式

前段时间公司一些同事在讨论单例模式(我是最渣的一个,都插不上嘴 T__T ),这个模式使用的频率很高,也可能是很多人最熟悉的设计模式,当然单例模式也算是最简单的设计模式之一吧,简单归简单,但是在实际使用的时候也会有一些坑. PS:对技术感兴趣的同鞋加群544645972一起交流 设计模式总目录 java/android 设计模式学习笔记目录 特点 确保某一个类只有一个实例,而且自行实例化并向整个系统提供这个实例. 单例模式的使用很广泛,比如:线程池(threadpool).缓存(cache).对

java/android 设计模式学习笔记(7)---装饰者模式

这篇将会介绍装饰者模式(Decorator Pattern),装饰者模式也称为包装模式(Wrapper Pattern),结构型模式之一,其使用一种对客户端透明的方式来动态的扩展对象的功能,同时它也是继承关系的一种替代方案之一,但比继承更加灵活.在现实生活中也可以看到很多装饰者模式的例子,或者可以大胆的说装饰者模式无处不在,就拿一件东西来说,可以给它披上无数层不一样的外壳,但是这件东西还是这件东西,外壳不过是用来扩展这个东西的功能而已,这就是装饰者模式,装饰者的这个角色也许各不相同但是被装饰的对

java/android 设计模式学习笔记(13)---享元模式

这篇我们来介绍一下享元模式(Flyweight Pattern),Flyweight 代表轻量级的意思,享元模式是对象池的一种实现.享元模式用来尽可能减少内存使用量,它适合用于可能存在大量重复对象的场景,缓存可共享的对象,来达到对象共享和避免创建过多对象的效果,这样一来就可以提升性能,避免内存移除和频繁 GC 等. 享元模式的一个经典使用案例是文本系统中图形显示所用的数据结构,一个文本系统能够显示的字符种类就是那么几十上百个,那么就定义这么些基础字符对象,存储每个字符的显示外形和其他的格式化数据

java/android 设计模式学习笔记(12)---组合模式

这篇我们来介绍一下组合模式(Composite Pattern),它也称为部分整体模式(Part-Whole Pattern),结构型模式之一.组合模式比较简单,它将一组相似的对象看作一个对象处理,并根据一个树状结构来组合对象,然后提供一个统一的方法去访问相应的对象,以此忽略掉对象与对象集合之间的差别.这个最典型的例子就是数据结构中的树了,如果一个节点有子节点,那么它就是枝干节点,如果没有子节点,那么它就是叶子节点,那么怎么把枝干节点和叶子节点统一当作一种对象处理呢?这就需要用到组合模式了. 转

java/android 设计模式学习笔记(9)---代理模式

这篇博客我们来介绍一下代理模式(Proxy Pattern),代理模式也成为委托模式,是一个非常重要的设计模式,不少设计模式也都会有代理模式的影子.代理在我们日常生活中也很常见,比如上网时连接的代理服务器地址,更比如我们平时租房子,将找房子的过程代理给中介等等,都是代理模式在日常生活中的使用例子. 代理模式中的代理对象能够连接任何事物:一个网络连接,一个占用很多内存的大对象,一个文件,或者是一些复制起来代价很高甚至根本不可能复制的一些资源.总之,代理是一个由客户端调用去访问幕后真正服务的包装对象

java/android 设计模式学习笔记(6)---适配器模式

这篇来介绍一下适配器模式(Adapter Pattern),适配器模式在开发中使用的频率也是很高的,像 ListView 和 RecyclerView 的 Adapter 等都是使用的适配器模式.在我们的实际生活中也有很多类似于适配器的例子,比如香港的插座和大陆的插座就是两种格式的,为了能够成功适配,一般会在中间加上一个电源适配器,形如: 这样就能够将原来不符合的现有系统和目标系统通过适配器成功连接. 说到底,适配器模式是将原来不兼容的两个类融合在一起,它有点类似于粘合剂,将不同的东西通过一种转

java/android 设计模式学习笔记(16)---命令模式

这篇博客我们来介绍一下命令模式(Command Pattern),它是行为型设计模式之一.命令模式相对于其他的设计模式更为灵活多变,我们接触比较多的命令模式个例无非就是程序菜单命令,如在操作系统中,我们点击关机命令,系统就会执行一系列的操作,如先是暂停处理事件,保存系统的一些配置,然后结束程序进程,最后调用内核命令关闭计算机等,对于这一系列的命令,用户不用去管,用户只需点击系统的关机按钮即可完成如上一系列的命令.而我们的命令模式其实也与之相同,将一系列的方法调用封装,用户只需调用一个方法执行,那