[Android]组件-进度条1

多式样ProgressBar

普通圆形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) { 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() 是用来获取其他进度条的进度值 

ProgressDialog

ProgressDialog中的圆形进度条
  
ProgressDialog一般用来表示一个系统任务或是开启任务时候的进度,有一种稍等的意思。
代码实现:

 ProgressDialog mypDialog=new ProgressDialog(this); //实例化 mypDialog.setProgressStyle(ProgressDialog.STYLE_SPINNER); //设置进度条风格,风格为圆形,旋转的 mypDialog.setTitle("Google"); //设置ProgressDialog 标题 mypDialog.setMessage(getResources().getString(R.string.second)); //设置ProgressDialog 提示信息 mypDialog.setIcon(R.drawable.android); //设置ProgressDialog 标题图标 mypDialog.setButton("Google",this); //设置ProgressDialog 的一个Button mypDialog.setIndeterminate(false); //设置ProgressDialog 的进度条是否不明确 mypDialog.setCancelable(true); //设置ProgressDialog 是否可以按退回按键取消 mypDialog.show(); //让ProgressDialog显示 

ProgressDialog中的长形进度条

代码实现:

 ProgressDialog mypDialog=new ProgressDialog(this); //实例化             mypDialog.setProgressStyle(ProgressDialog.STYLE_HORIZONTAL);             //设置进度条风格,风格为长形,有刻度的             mypDialog.setTitle("地狱怒兽");             //设置ProgressDialog 标题             mypDialog.setMessage(getResources().getString(R.string.second));             //设置ProgressDialog 提示信息             mypDialog.setIcon(R.drawable.android);             //设置ProgressDialog 标题图标             mypDialog.setProgress(59);             //设置ProgressDialog 进度条进度             mypDialog.setButton("地狱曙光",this);             //设置ProgressDialog 的一个Button             mypDialog.setIndeterminate(false);             //设置ProgressDialog 的进度条是否不明确             mypDialog.setCancelable(true);             //设置ProgressDialog 是否可以按退回按键取消             mypDialog.show();             //让ProgressDialog显示 

AlertDialog.Builder

AlertDialog中的圆形ProgressBar

①先来设计一个Layout,待会儿作为一个View,加入AlertDialog.Builder

 <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"     android:layout_gravity="center_horizontal"     android:layout_width="wrap_content"     android:layout_height="wrap_content">     <LinearLayout android:id="@+id/LinearLayout01"     android:layout_width="wrap_content"     android:layout_height="wrap_content"> </LinearLayout>     <ProgressBar android:layout_gravity="center_vertical|center_horizontal"         android:layout_height="wrap_content"         android:progress="57"         android:id="@+id/myView_ProgressBar2"         android:layout_width="wrap_content"> </ProgressBar> </LinearLayout>\ 

②代码-基于Layout的AlertDialog,还有基于基本的AlertDialog,本文没有描述

 private AlertDialog AlertD; //定义提示对话框 private AlertDialog.Builder builder; //定义提示对话框床假期 private LayoutInflater layoutInflater; //定义布局过滤器 private View myLayout; //定义布局 layoutInflater=this.getSystemService(LAYOUT_INFLATER_SERVICE); //获得系统的布局过滤服务 myLayout=layoutInflater.inflate(R.layout.roundprogress, null); //得到事先设计好的布局 builder=new AlertDialog.Builder(this); //初始化提示对话框 builder.setTitle(getResources().getString(R.string.title)); //设置对话框标题 builder.setIcon(R.drawable.icon); //设置对话框图标 builder.setMessage(getResources().getString(R.string.view)); //设置对话框提示信息 builder.setView(myLayout); //设置对话框中的View AlertD=builder.create(); //利用AlertDialog类的创建器创建AlertDialog对话框 AlertD.show(); //让对话框显示 

AlertDialog中的长形ProgressBar(可控制)

①先来设计一个Layout,待会儿作为一个View,加入AlertDialog.Builder

 <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"     android:layout_gravity="center_horizontal" android:layout_width="wrap_content"     android:layout_height="wrap_content">     <Button android:layout_height="wrap_content" android:text="-"         android:layout_width="50dp" android:id="@+id/myView_BT_Down"> </Button>     <ProgressBar android:layout_gravity="center_vertical"         android:layout_height="wrap_content" style="?android:attr/progressBarStyleHorizontal"         android:id="@+id/myView_ProgressBar" android:progress="57"         android:layout_width="178dp"> </ProgressBar>     <Button android:layout_height="wrap_content" android:text="+"         android:layout_width="50dp" android:id="@+id/myView_BT_Up"> </Button> </LinearLayout> 

②代码罗

 private AlertDialog.Builder AlterD,AlterD2; //定义提示对话框 private LayoutInflater layoutInflater; //定义布局过滤器 private LinearLayout myLayout; //定义布局 layoutInflater=(LayoutInflater) getSystemService(this.LAYOUT_INFLATER_SERVICE); //获得系统的布局过滤服务 myLayout=(LinearLayout) layoutInflater.inflate(R.layout.myview, null); //得到事先设计好的布局 myup=(Button) myLayout.findViewById(R.id.myView_BT_Up); mydown=(Button) myLayout.findViewById(R.id.myView_BT_Down); mypro=(ProgressBar)myLayout.findViewById(R.id.myView_ProgressBar); //通过myLayout.findViewById来获取自定义View中的Widget控件元素 myup.setOnClickListener(this); //设置对话框View中的按钮监听器 mydown.setOnClickListener(this); //设置对话框View中的按钮监听器 mypro.setProgress(Tag); //设置一个Tag作为进度值 AlterD.setTitle(getResources().getString(R.string.RectO)); //设置对话框标题 AlterD.setIcon(R.drawable.mb); //设置对话框图标 AlterD.setMessage(getResources().getString(R.string.ADDView)); //设置对话框提示信息 AlterD.setView(myLayout); //设置对话框添加的View AlterD.setPositiveButton("OK", new DialogInterface.OnClickListener(){     @Override     public void onClick(DialogInterface dialog, int which) {         // TODO Auto-generated method stub         //MyProgressBar.Tag=mypro.getProgress();     }}); //设置对话框按钮,以及按钮的事件监听器 AlterD.show(); //让对话框显示 

③进度条进度值的按钮事件

 myup.setOnClickListener(this); //设置对话框View中的按钮监听器 mydown.setOnClickListener(this); //设置对话框View中的按钮监听器 对应的代码:     @Override     public void onClick(View button) {         // TODO Auto-generated method stub         SwitchUPorDown(button);     }     private void SwitchUPorDown(View button) {         switch (button.getId()) {                 case R.id.myView_BT_Up: {             mypro.incrementProgressBy(1);         }             break;         case R.id.myView_BT_Down: {             mypro.incrementProgressBy(-1);         }             break;         default:             break;         }     } 

App Widget中的进度条

Widget中的圆形ProgressBar

这个很简单,在Widget中没有多大意思,不再敷述。

Widget中的长形ProgressBar(可控制)

Widget的实现就不再重复,假设您已经把Widget布局,相应设置已经设置好了。也可以在桌面加入类似上面图中的样式。
现在我们来实现一下按钮事件,与进度条的交互。
下面还是简单讲解一下Widget的设计与部署。

①设计Widget布局

 <?xml version="1.0" encoding="utf-8"?> <LinearLayout     xmlns:android="http://schemas.android.com/apk/res/android"     android:background="@drawable/widget"     android:layout_height="74dp"     android:layout_width="296dp">     <Button         android:layout_height="wrap_content"         android:text="-"         android:layout_gravity="center_vertical"         android:layout_width="50dp"         android:id="@+id/widget_BT_Down"         android:layout_marginLeft="10dp">     </Button>     <ProgressBar         android:layout_gravity="center_vertical"         android:layout_height="wrap_content"         style="?android:attr/progressBarStyleHorizontal"         android:layout_width="178dp"         android:id="@+id/widget_ProgressBar">    </ProgressBar>     <Button         android:layout_height="wrap_content"         android:text="+"         android:layout_gravity="center_vertical"         android:layout_width="50dp"         android:id="@+id/widget_BT_Up">    </Button> </LinearLayout> 

②新增一个.res/xml目录,加入appwidget-provider

 <?xml version="1.0" encoding="utf-8"?> <appwidget-provider     xmlns:android="http://schemas.android.com/apk/res/android"     android:initialLayout="@layout/widgetlayout"     android:updatePeriodMillis="8660000"     android:minWidth="296dp"     android:minHeight="74dp"> </appwidget-provider> 

③实现一个AppWidgetProvider子类

 package zyf.test.ProgressBar; import android.appwidget.AppWidgetManager; import android.appwidget.AppWidgetProvider; import android.content.Context; import android.content.Intent; public class App extends AppWidgetProvider {     @Override     public void onEnabled(Context context) {         // TODO Auto-generated method stub         super.onEnabled(context);     }     @Override     public void onReceive(Context context, Intent intent) {         // TODO Auto-generated method stub         super.onReceive(context, intent);     }     @Override     public void onUpdate(Context context, AppWidgetManager appWidgetManager,             int[] appWidgetIds) {         // TODO Auto-generated method stub         super.onUpdate(context, appWidgetManager, appWidgetIds);     } } 

④配置Manifest,进行注册

 <receiver android:name="AppWidget">     <intent-filter>     <action android:name="android.appwidget.action.APPWIDGET_UPDATE"></action>     </intent-filter>     <meta-data         android:resource="@xml/appwidget"         android:name="android.appwidget.provider">     </meta-data> </receiver> 

这里实现按钮与进度条的交互。(Widget自己广播发送与接收)

①按钮的消息发送

 @Override     public void onUpdate(Context context, AppWidgetManager appWidgetManager,             int[] appWidgetIds) {         // TODO Auto-generated method stub         final int N = appWidgetIds.length;         // Perform this loop procedure for each App Widget that belongs to this provider         for (int i=0; i<N; i++) {             int appWidgetId = appWidgetIds;             RemoteViews views= new RemoteViews(context.getPackageName(), R.layout.widgetlayout);             Intent UPintent=new Intent("zyf.test.widget.UP");             Intent DOWNintent=new Intent("zyf.test.widget.DOWN");             //实例化 两个带有Action的Intent             PendingIntent pendingIntentUp =PendingIntent.getBroadcast(context, 0, UPintent, 0);             PendingIntent pendingIntentDown =PendingIntent.getBroadcast(context, 0, DOWNintent, 0);             //实例化两个以Intent来构造的PendingIntent             views.setOnClickPendingIntent(R.id.widget_BT_Up, pendingIntentUp);             views.setOnClickPendingIntent(R.id.widget_BT_Down, pendingIntentDown);             //给View上的两个按钮绑定事件,这里是广播消息的发送             appWidgetManager.updateAppWidget(appWidgetId, views);         }     } 

②Widget自身消息接收,使用intent.getAction()来获取Action

 @Override     public void onReceive(Context context, Intent intent) {         // TODO Auto-generated method stub         super.onReceive(context, intent);         if(intent.getAction().equals("zyf.test.widget.UP")){             Tag+=5;             if(Tag>100){                 Tag=100;             }             views.setProgressBar(R.id.widget_ProgressBar, 100, Tag, false);             appManager.updateAppWidget(thisWidget, views);         }         if(intent.getAction().equals("zyf.test.widget.DOWN")){             Tag-=5;             if(Tag<0){                 Tag=0;             }             views.setProgressBar(R.id.widget_ProgressBar, 100, Tag, false);             appManager.updateAppWidget(thisWidget, views);         }     } 

③进度条的进度值设置

 views.setProgressBar(R.id.widget_ProgressBar, 100, Tag, false); //设置Widget上的进度条的进度值 //第一个参数,Widget上进度条ID //第二个参数,进度条最大值 //第三个参数Tag,一个int值,就是设置的进度值 //第四个参数,是否是要进度条不确定 

注意了,Widget自身的onReceive()方法如果要接收其他的Action广播。那就必须在Manifest中,在Intent-filter中添加Action:

 <receiver android:name="AppWidget">     <intent-filter>         <action android:name="android.appwidget.action.APPWIDGET_UPDATE"></action>                 <action android:name="zyf.test.widget.UP"></action>                 <action android:name="zyf.test.widget.DOWN"></action>     </intent-filter>     <meta-data         android:resource="@xml/appwidget"         android:name="android.appwidget.provider">     </meta-data> </receiver> 

 

[Android]组件-进度条1,布布扣,bubuko.com

时间: 2024-10-03 23:29:32

[Android]组件-进度条1的相关文章

Android自定义进度条样式

最近在做一个widget,上面需要一个progressbar,产品经理和设计师给出来的东西是要实现一个圆角的progress和自定义的颜色,研究一小下,分享出来给大家哦. 测试于:Android4.0+ 操作步骤: 1.创建你的layout文件引用progressbar如下,标红处引用你自定的样式: <ProgressBar android:id="@+id/progressDownload" style="?android:attr/progressBarStyleH

Android自定义进度条-带文本(文字进度)的水平进度条(ProgressBar)

/** * 带文本提示的进度条 */ public class TextProgressBar extends ProgressBar { private String text; private Paint mPaint; public TextProgressBar(Context context) { super(context); initText(); } public TextProgressBar(Context context, AttributeSet attrs, int d

Android中进度条类型的控件定义和妙用技巧

Android中进度条控件有3个(不算ProgressDialog),分别是ProgressBar,SeekBar和RatingBar,对于自定义样式来说又得按照需求分为2中情况,第一种是刻度型,第二种是循环类型. 第一种是"刻度型",也就是他有起点和终点,起点值小于终点值 这种样式的修改,要修改三个属性即可 分别是:背景(主要是进度的轨道样式),第一级别滚动条progressDrawable,第二级别progressDrawable 遗憾的是Android提供的api很难设置,不过可

Android之进度条2

我之前有写过一篇“Android之进度条1”,那个是条形的进度条(显示数字进度),这次实现圆形进度条. 点击查看Android之进度条1:http://www.cnblogs.com/caidupingblogs/p/5102745.html> MainActivity继承Activity实现Runnable接口: package com.cdp.progressbar; import android.app.Activity; import android.os.Bundle; import

android 自定义进度条颜色

先看图 基于产品经理各种自定义需求,经过查阅了解,下面是自己对Android自定义进度条的学习过程!   这个没法了只能看源码了,还好下载了源码, sources\base\core\res\res\  下应有尽有,修改进度条颜色只能找progress ,因为是改变样式,首先找styles.xml 找到xml后,进去找到 [html] view plaincopyprint? <span style="font-size: 18px;">    <style name

android的进度条使用

android的进度条 1.实现的效果 2.布局代码 先写一个my_browser.xml文件 存放WebView <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" a

【Android开发】高级组件-进度条

当一个应用在后台执行时,前台界面不会有任何信息,这是用户根本不知道程序是否在执行以及执行进度等,因此需要使用进度条来提示程序执行的进度.在Android中,进度条(ProgressBar)用于向用户显示某个耗时操作完成的百分比. 在屏幕中添加进度天,可以在XML布局文件中通过标记添加,基本语法格式如下:    属性列表 > ProgressBar组件支持的XML属性如下所... http://songtaste.com/user/10310357/infohttp://songtaste.com

android之进度条组件ProgressBar

首先是main.xml文件 代码如下: <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:orientation="vertical" android:layout_width="fill_parent" androi

安卓高级组件-----进度条

进度条组件是安卓重要组件之一.当后台某个程序执行时,前台进度条动态显示了程序执行进度的百分比.是耗时较长的程序让用户觉得在自己的掌控之中,提高程序的友好型. 安卓支支持几种风格的进度条,能通过style属性呢设置进度条风格,该属性如下: @android:style/Widget.ProgressBar.Horizontal    水平进度条 @android:style/Widget.ProgressBar.Inverse        普通环形进度条 @android:style/Widge