android 进度条的样式

Android 进度条详解
该类型进度条也就是一个表示运转的过程,例如发送短信,连接网络等等,表示一个过程正在执行中。

一般只要在XML布局中定义就可以了。
  1. <progressBar android:id="@+id/widget43"
  2. <wbr><wbr><wbr><wbr>android:layout_width="wrap_content"<br></wbr></wbr></wbr></wbr>
  3. <wbr><wbr><wbr><wbr>android:layout_height="wrap_content"<wbr><wbr><br></wbr></wbr></wbr></wbr></wbr></wbr>
  4. <wbr><wbr><wbr><wbr>android:layout_gravity="center_vertical"&gt;<br></wbr></wbr></wbr></wbr>
  5. </ProgressBar>
此时,没有设置它的风格,那么它就是圆形的,一直会旋转的进度条。

各大小样式圆形ProgressBar


超大号圆形ProgressBar


此时,给设置一个style风格属性后,该ProgressBar就有了一个风格,这里大号ProgressBar的风格是:
  1. style="?android:attr/progressBarStyleLarge"
完整XML定义是:
  1. <progressBar android:id="@+id/widget196"
  2. <wbr><wbr><wbr><wbr>android:layout_width="wrap_content"<br></wbr></wbr></wbr></wbr>
  3. <wbr><wbr><wbr><wbr>android:layout_height="wrap_content"<br></wbr></wbr></wbr></wbr>
  4. <wbr><wbr><wbr><wbr>style="?android:attr/progressBarStyleLarge"&gt;<br></wbr></wbr></wbr></wbr>
  5. </ProgressBar>
小号圆形ProgressBar



小号ProgressBar对应的风格是:
  1. style="?android:attr/progressBarStyleSmall"
完整XML定义是:
  1. <progressBar android:id="@+id/widget108"
  2. <wbr><wbr><wbr><wbr>android:layout_width="wrap_content"<br></wbr></wbr></wbr></wbr>
  3. <wbr><wbr><wbr><wbr>android:layout_height="wrap_content"<br></wbr></wbr></wbr></wbr>
  4. <wbr><wbr><wbr><wbr>style="?android:attr/progressBarStyleSmall"&gt;<br></wbr></wbr></wbr></wbr>
  5. </ProgressBar>
标题型圆形ProgressBar





标题型ProgressBar对应的风格是:
  1. style="?android:attr/progressBarStyleSmallTit<wbr>le" </wbr>
完整XML定义是:
  1. <progressBar android:id="@+id/widget110"
  2. <wbr><wbr> android:layout_width="wrap_content"<br></wbr></wbr>
  3. <wbr><wbr> android:layout_height="wrap_content"<br></wbr></wbr>
  4. <wbr><wbr> style="?android:attr/progressBarStyleSmallTit<wbr>le"&gt;<br></wbr></wbr></wbr>
  5. </ProgressBar>
代码中实现:
  1. @Override
  2. <wbr><wbr> protected void onCreate(Bundle savedInstanceState) {<br></wbr></wbr>
  3. <wbr><wbr><wbr><wbr><wbr><wbr>// TODO Auto-generated method stub<br></wbr></wbr></wbr></wbr></wbr></wbr>
  4. <wbr><wbr><wbr><wbr><wbr><wbr>super.onCreate(savedInstanceState);<br></wbr></wbr></wbr></wbr></wbr></wbr>
  5. <wbr><wbr><wbr><wbr><wbr><wbr>requestWindowFeature(Window.FEATURE_INDETERMINATE_PROGRESS);<br></wbr></wbr></wbr></wbr></wbr></wbr>
  6. <wbr><wbr><wbr><wbr><wbr><wbr>//请求窗口特色风格,这里设置成不明确的进度风格<br></wbr></wbr></wbr></wbr></wbr></wbr>
  7. <wbr><wbr><wbr><wbr><wbr><wbr>setContentView(R.layout.second);<br></wbr></wbr></wbr></wbr></wbr></wbr>
  8. <wbr><wbr><wbr><wbr><wbr><wbr>setProgressBarIndetermin<wbr>ateVisibility(true);<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr>
  9. <wbr><wbr><wbr><wbr><wbr><wbr>//设置标题栏中的不明确的进度条是否可以显示<br></wbr></wbr></wbr></wbr></wbr></wbr>
  10. <wbr><wbr> } </wbr></wbr>
长形进度条

布局中的长形进度条


①首先在XML进行布局
  1. <progressBar android:id="@+id/progressbar_updown"
  2. <wbr><wbr><wbr><wbr><wbr><wbr>android:layout_width="200dp"<br></wbr></wbr></wbr></wbr></wbr></wbr>
  3. <wbr><wbr><wbr><wbr><wbr><wbr>android:layout_height="wrap_content"<br></wbr></wbr></wbr></wbr></wbr></wbr>
  4. <wbr><wbr><wbr><wbr><wbr><wbr>style="?android:attr/progressBarStyleHorizont<wbr>al"<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr>
  5. <wbr><wbr><wbr><wbr><wbr><wbr>android:layout_gravity="center_vertical"<br></wbr></wbr></wbr></wbr></wbr></wbr>
  6. <wbr><wbr><wbr><wbr><wbr><wbr>android:max="100"<br></wbr></wbr></wbr></wbr></wbr></wbr>
  7. <wbr><wbr><wbr><wbr><wbr><wbr>android:progress="50"<br></wbr></wbr></wbr></wbr></wbr></wbr>
  8. <wbr><wbr><wbr><wbr><wbr><wbr>android:secondaryProgress="70"<wbr><wbr> &gt; </wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>
讲解:
style="?android:attr/progressBarStyleHorizont<wbr>al"<wbr><wbr><br></wbr></wbr></wbr>设置风格为长形
android:max="100"<wbr><wbr><br></wbr></wbr>最大进度值为100
android:progress="50"<wbr><wbr><br></wbr></wbr>初始化的进度值
android:secondaryProgress="70"初始化的底层第二个进度值
android:layout_gravity="center_vertical"<wbr><wbr><br></wbr></wbr>垂直居中


②代码中运用
  1. private ProgressBar myProgressBar;
  2. //定义ProgressBar
  3. myProgressBar = (ProgressBar) findViewById(R.id.progressbar_updown);
  4. //ProgressBar通过ID来从XML中获取
  5. myProgressBar.incrementProgressBy(5);
  6. //ProgressBar进度值增加5
  7. myProgressBar.incrementProgressBy(-5);
  8. //ProgressBar进度值减少5
  9. myProgressBar.incrementSecondaryProgre<wbr>ssBy(5);<br></wbr>
  10. //ProgressBar背后的第二个进度条 进度值增加5
  11. myProgressBar.incrementSecondaryProgre<wbr>ssBy(-5);<br></wbr>
  12. //ProgressBar背后的第二个进度条 进度值减少5
页面标题中的长形进度条


代码实现:
①先设置一下窗口风格特性
  1. requestWindowFeature(Window.FEATURE_PROGRESS);
  2. //请求一个窗口进度条特性风格
  3. setContentView(R.layout.main);
  4. setProgressBarVisibility<wbr>(true);<br></wbr>
  5. //设置进度条可视
②然后设置进度值
  1. setProgress(myProgressBar.getProgress() * 100);
  2. //设置标题栏中前景的一个进度条进度值
  3. setSecondaryProgress(myProgressBar.getSecondaryProgress() * 100);
  4. //设置标题栏中后面的一个进度条进度值
  5. //ProgressBar.getSecondaryProgress() 是用来获取其他进度条的进度值
ProgressDialog

ProgressDialog中的圆形进度条
<wbr><wbr></wbr></wbr><wbr><wbr><br> ProgressDialog一般用来表示一个系统任务或是开启任务时候的进度,有一种稍等的意思。<br> 代码实现:<br><br></wbr></wbr>
  1. <wbr><wbr>ProgressDialog mypDialog=new ProgressDialog(this);<br></wbr></wbr>
  2. <wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>//实例化<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>
  3. <wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>mypDialog.setProgressStyle(ProgressDialog.STYLE_SPINNER);<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>
  4. <wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>//设置进度条风格,风格为圆形,旋转的<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>
  5. <wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>mypDialog.setTitle("Google");<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>
  6. <wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>//设置ProgressDialog 标题<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>
  7. <wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>mypDialog.setMessage(getResources().getString(R.string.second));<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>
  8. <wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>//设置ProgressDialog 提示信息<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>
  9. <wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>mypDialog.setIcon(R.drawable.android);<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>
  10. <wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>//设置ProgressDialog 标题图标<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>
  11. <wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>mypDialog.setButton("Google",this);<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>
  12. <wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>//设置ProgressDialog 的一个Button<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>
  13. <wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>mypDialog.setIndeterminate(false);<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>
  14. <wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>//设置ProgressDialog 的进度条是否不明确<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>
  15. <wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>mypDialog.setCancelable(true);<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>
  16. <wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>//设置ProgressDialog 是否可以按退回按键取消<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>
  17. <wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>mypDialog.show();<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>
  18. <wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>//让ProgressDialog显示 </wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>
ProgressDialog中的长形进度条
<wbr><wbr><wbr><wbr><br><br> 代码实现:<br><div> <div> <ol> <li><span style="font-size:24px"><span style="font-size:16px">ProgressDialog mypDialog=new ProgressDialog(this);<br></span></span></li> <li>//实例化<br> </li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>mypDialog.setProgressStyle(ProgressDialog.STYLE_HORIZONTAL);<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>//设置进度条风格,风格为长形,有刻度的<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>mypDialog.setTitle("地狱怒兽");<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>//设置ProgressDialog 标题<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>mypDialog.setMessage(getResources().getString(R.string.second));<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>//设置ProgressDialog 提示信息<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>mypDialog.setIcon(R.drawable.android);<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>//设置ProgressDialog 标题图标<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>mypDialog.setProgress(59);<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>//设置ProgressDialog 进度条进度<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>mypDialog.setButton("地狱曙光",this);<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>//设置ProgressDialog 的一个Button<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>mypDialog.setIndeterminate(false);<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>//设置ProgressDialog 的进度条是否不明确<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>mypDialog.setCancelable(true);<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>//设置ProgressDialog 是否可以按退回按键取消<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>mypDialog.show();<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>//让ProgressDialog显示<wbr><wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> </ol> </div> </div> <span style="font-size:24px"><strong>AlertDialog.Builder</strong></span><br><br><span style="font-size:18px"><strong>AlertDialog中的圆形ProgressBar</strong></span><br><br> ①先来设计一个Layout,待会儿作为一个View,加入AlertDialog.Builder <div> <div> <ol> <li>&lt;?xml version="1.0" encoding="utf-8"?&gt;<br> </li> <li>&lt;LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"<br> </li> <li><wbr><wbr> android:layout_gravity="center_horizontal"<br></wbr></wbr></li> <li><wbr><wbr> android:layout_width="wrap_content"<br></wbr></wbr></li> <li><wbr><wbr> android:layout_height="wrap_content"&gt;<br></wbr></wbr></li> <li><wbr><wbr> &lt;LinearLayout android:id="@+id/LinearLayout01"<br></wbr></wbr></li> <li><wbr><wbr> android:layout_width="wrap_content"<br></wbr></wbr></li> <li><wbr><wbr> android:layout_height="wrap_content"&gt;<br></wbr></wbr></li> <li>&lt;/LinearLayout&gt;<br> </li> <li><wbr><wbr> &lt;ProgressBar android:layout_gravity="center_vertical|center_horizontal"<br></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>android:layout_height="wrap_content"<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>android:progress="57"<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>android:id="@+id/myView_ProgressBar2"<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>android:layout_width="wrap_content"&gt;<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li>&lt;/ProgressBar&gt;<br> </li> <li>&lt;/LinearLayout&gt; </li> </ol> </div> </div> ②代码罗 <div> <div> <ol> <li>private AlertDialog.Builder AlterD,AlterD2;<br> </li> <li>//定义提示对话框<br> </li> <li>private LayoutInflater layoutInflater;<br> </li> <li>//定义布局过滤器<br> </li> <li>private LinearLayout myLayout;<br> </li> <li>//定义布局<br> </li> <li>layoutInflater2=(LayoutInflater) getSystemService(this.LAYOUT_INFLATER_SERVICE);<br> </li> <li>//获得系统的布局过滤服务<br> </li> <li>myLayout2=(LinearLayout) layoutInflater2.inflate(R.layout.roundprogress, null);<br> </li> <li>//得到事先设计好的布局<br> </li> <li>AlterD2.setTitle(getResources().getString(R.string.RoundO));<br> </li> <li>//设置对话框标题<br> </li> <li>AlterD2.setIcon(R.drawable.ma);<br> </li> <li>//设置对话框图标<br> </li> <li>AlterD2.setMessage(getResources().getString(R.string.ADDView));<br> </li> <li>//设置对话框提示信息<br> </li> <li>AlterD2.setView(myLayout2);<br> </li> <li>//设置对话框中的View<br> </li> <li>AlterD2.show();<br> </li> <li>//让对话框显示 </li> </ol> </div> </div> <span style="font-size:18px"><strong>AlertDialog中的长形ProgressBar(可控制)</strong></span><br><br> ①先来设计一个Layout,待会儿作为一个View,加入AlertDialog.Builder <div> <div> <ol> <li>&lt;?xml version="1.0" encoding="utf-8"?&gt;<br> </li> <li>&lt;LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"<br> </li> <li><wbr><wbr> android:layout_gravity="center_horizontal"<br></wbr></wbr></li> <li>android:layout_width="wrap_content"<br> </li> <li><wbr><wbr> android:layout_height="wrap_content"&gt;<br></wbr></wbr></li> <li><wbr><wbr> &lt;Button<br></wbr></wbr></li> <li>android:layout_height="wrap_content"<br> </li> <li>android:text="-"<br> </li> <li><wbr><wbr><wbr><wbr><wbr><wbr>android:layout_width="50dp"<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li>android:id="@+id/myView_BT_Down"&gt;<br> </li> <li>&lt;/Button&gt;<br> </li> <li><wbr><wbr> &lt;ProgressBar<br></wbr></wbr></li> <li>android:layout_gravity="center_vertical"<br> </li> <li><wbr><wbr><wbr><wbr><wbr><wbr>android:layout_height="wrap_content"<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li>style="?android:attr/progressBarStyleHorizont<wbr>al"<br></wbr> </li> <li><wbr><wbr><wbr><wbr><wbr><wbr>android:id="@+id/myView_ProgressBar"<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li>android:progress="57"<br> </li> <li><wbr><wbr><wbr><wbr><wbr><wbr>android:layout_width="178dp"&gt;<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li>&lt;/ProgressBar&gt;<br> </li> <li><wbr><wbr> &lt;Button android:layout_height="wrap_content"<br></wbr></wbr></li> <li>android:text="+"<br> </li> <li><wbr><wbr><wbr><wbr><wbr><wbr>android:layout_width="50dp"<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li>android:id="@+id/myView_BT_Up"&gt;<br> </li> <li>&lt;/Button&gt;<br> </li> <li>&lt;/LinearLayout&gt; </li> </ol> </div> </div> ②代码罗 <div> <div> <ol> <li>private AlertDialog.Builder AlterD,AlterD2;<br> </li> <li>//定义提示对话框<br> </li> <li>private LayoutInflater layoutInflater;<br> </li> <li>//定义布局过滤器<br> </li> <li>private LinearLayout myLayout;<br> </li> <li>//定义布局<br> </li> <li>layoutInflater=(LayoutInflater) getSystemService(this.LAYOUT_INFLATER_SERVICE);<br> </li> <li>//获得系统的布局过滤服务<br> </li> <li>myLayout=(LinearLayout) layoutInflater.inflate(R.layout.myview, null);<br> </li> <li>//得到事先设计好的布局<br> </li> <li><br></li> <li>myup=(Button) myLayout.findViewById(R.id.myView_BT_Up);<br> </li> <li>mydown=(Button) myLayout.findViewById(R.id.myView_BT_Down);<br> </li> <li>mypro=(ProgressBar)myLayout.findViewById(R.id.myView_ProgressBar);<br> </li> <li>//通过myLayout.findViewById来获取自定义View中的Widget控件元素<br> </li> <li><br></li> <li>myup.setOnClickListener(this);<br> </li> <li>//设置对话框View中的按钮监听器<br> </li> <li>mydown.setOnClickListener(this);<br> </li> <li>//设置对话框View中的按钮监听器<br> </li> <li>mypro.setProgress(Tag);<br> </li> <li>//设置一个Tag作为进度值<br> </li> <li>AlterD.setTitle(getResources().getString(R.string.RectO));<br> </li> <li>//设置对话框标题<br> </li> <li>AlterD.setIcon(R.drawable.mb);<br> </li> <li>//设置对话框图标<br> </li> <li>AlterD.setMessage(getResources().getString(R.string.ADDView));<br> </li> <li>//设置对话框提示信息<br> </li> <li>AlterD.setView(myLayout);<br> </li> <li>//设置对话框添加的View<br> </li> <li>AlterD.setPositiveButton("OK", new DialogInterface.OnClickListener(){<br> </li> <li><wbr><wbr> @Override<br></wbr></wbr></li> <li><wbr><wbr> public void onClick(DialogInterface dialog, int which) {<br></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>// TODO Auto-generated method stub<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>MyProgressBar.Tag=mypro.getProgress();<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr> }});<br></wbr></wbr></li> <li>//设置对话框按钮,以及按钮的事件监听器<br> </li> <li>AlterD.show();<br> </li> <li>//让对话框显示 </li> </ol> </div> </div> ③进度条进度值的按钮事件 <div> <div> <ol> <li>myup.setOnClickListener(this);<br> </li> <li>//设置对话框View中的按钮监听器<br> </li> <li>mydown.setOnClickListener(this);<br> </li> <li>//设置对话框View中的按钮监听器<br> </li> <li>对应的代码:<br> </li> <li><wbr><wbr> @Override<br></wbr></wbr></li> <li><wbr><wbr> public void onClick(View button) {<br></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>// TODO Auto-generated method stub<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>SwitchUPorDown(button);<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr> }<br></wbr></wbr></li> <li><br></li> <li><wbr><wbr> private void SwitchUPorDown(View button) {<br></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>switch (button.getId()) {<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr> case R.id.myView_BT_Up: {<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>mypro.incrementProgressBy(1);<wbr><wbr><br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>}<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>break;<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>case R.id.myView_BT_Down: {<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>mypro.incrementProgressBy(-1);<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>}<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>break;<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>default:<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>break;<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>}<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr> } </wbr></wbr></li> </ol> </div> </div> <span style="font-size:24px"><strong>App Widget中的进度条</strong></span><br><br><br><span style="font-size:18px"><strong>Widget中的圆形ProgressBar</strong></span><br><br> 这个很简单,在Widget中没有多大意思,不再敷述。<br><br><span style="font-size:18px"><strong>Widget中的长形ProgressBar(可控制)</strong></span><br><br> Widget的实现就不再重复,假设您已经把Widget布局,相应设置已经设置好了。也可以在桌面加入类似上面图中的样式。<br> 现在我们来实现一下按钮事件,与进度条的交互。<br> 下面还是简单讲解一下Widget的设计与部署。<br><br><br> ①设计Widget布局 <div> <div> <ol> <li>&lt;?xml version="1.0" encoding="utf-8"?&gt;<br> </li> <li>&lt;LinearLayout<br> </li> <li><wbr><wbr> xmlns:android="http://schemas.android.com/apk/res/android"<br></wbr></wbr></li> <li><wbr><wbr> android:background="@drawable/widget"<br></wbr></wbr></li> <li><wbr><wbr> android:layout_height="74dp"<br></wbr></wbr></li> <li><wbr><wbr> android:layout_width="296dp"&gt;<br></wbr></wbr></li> <li><wbr><wbr> &lt;Button<br></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>android:layout_height="wrap_content"<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>android:text="-"<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>android:layout_gravity="center_vertical"<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>android:layout_width="50dp"<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>android:id="@+id/widget_BT_Down"<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>android:layout_marginLeft="10dp"&gt;<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr> &lt;/Button&gt;<br></wbr></wbr></li> <li><wbr><wbr> &lt;ProgressBar<br></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>android:layout_gravity="center_vertical"<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>android:layout_height="wrap_content"<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>style="?android:attr/progressBarStyleHorizont<wbr>al"<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>android:layout_width="178dp"<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>android:id="@+id/widget_ProgressBar"&gt;<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr>&lt;/ProgressBar&gt;<br></wbr></wbr></li> <li><wbr><wbr> &lt;Button<br></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>android:layout_height="wrap_content"<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>android:text="+"<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>android:layout_gravity="center_vertical"<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>android:layout_width="50dp"<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>android:id="@+id/widget_BT_Up"&gt;<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr>&lt;/Button&gt;<br></wbr></wbr></li> <li>&lt;/LinearLayout&gt; </li> </ol> </div> </div> ②新增一个.res/xml目录,加入appwidget-provider <div> <div> <ol> <li>&lt;?xml version="1.0" encoding="utf-8"?&gt;<br> </li> <li>&lt;appwidget-provider<br> </li> <li><wbr><wbr> xmlns:android="http://schemas.android.com/apk/res/android"<br></wbr></wbr></li> <li><wbr><wbr> android:initialLayout="@layout/widgetlayout"<br></wbr></wbr></li> <li><wbr><wbr> android:updatePeriodMillis="8660000"<br></wbr></wbr></li> <li><wbr><wbr> android:minWidth="296dp"<br></wbr></wbr></li> <li><wbr><wbr> android:minHeight="74dp"&gt;<br></wbr></wbr></li> <li>&lt;/appwidget-provider&gt; </li> </ol> </div> </div> ③实现一个AppWidgetProvider子类 <div> <div> <ol> <li>package zyf.test.ProgressBar;<br> </li> <li>import android.appwidget.AppWidgetManager;<br> </li> <li>import android.appwidget.AppWidgetProvider;<br> </li> <li>import android.content.Context;<br> </li> <li>import android.content.Intent;<br> </li> <li><br></li> <li>public class App extends AppWidgetProvider {<br> </li> <li><br></li> <li><wbr><wbr> @Override<br></wbr></wbr></li> <li><wbr><wbr> public void onEnabled(Context context) {<br></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>// TODO Auto-generated method stub<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>super.onEnabled(context);<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr> }<br></wbr></wbr></li> <li><br></li> <li><wbr><wbr> @Override<br></wbr></wbr></li> <li><wbr><wbr> public void onReceive(Context context, Intent intent) {<br></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>// TODO Auto-generated method stub<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>super.onReceive(context, intent);<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr> }<br></wbr></wbr></li> <li><br></li> <li><wbr><wbr> @Override<br></wbr></wbr></li> <li><wbr><wbr> public void onUpdate(Context context, AppWidgetManager appWidgetManager,<br></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>int[] appWidgetIds) {<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>// TODO Auto-generated method stub<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>super.onUpdate(context, appWidgetManager, appWidgetIds);<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr> }<br></wbr></wbr></li> <li><br></li> <li>} </li> </ol> </div> </div> ④配置Manifest,进行注册 <div> <div> <ol> <li>&lt;receiver android:name="AppWidget"&gt;<br> </li> <li><wbr><wbr> &lt;intent-filter&gt;<br></wbr></wbr></li> <li><wbr><wbr> &lt;action android:name="android.appwidget.action.APPWIDGET_UPDATE"&gt;&lt;/action&gt;<br></wbr></wbr></li> <li><wbr><wbr> &lt;/intent-filter&gt;<br></wbr></wbr></li> <li><wbr><wbr> &lt;meta-data<wbr><wbr><br></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>android:resource="@xml/appwidget"<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>android:name="android.appwidget.provider"&gt;<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr> &lt;/meta-data&gt;<br></wbr></wbr></li> <li>&lt;/receiver&gt; </li> </ol> </div> </div> 这里实现按钮与进度条的交互。(Widget自己广播发送与接收)<br><br> ①按钮的消息发送 <div> <div> <ol> <li>@Override<br> </li> <li><wbr><wbr> public void onUpdate(Context context, AppWidgetManager appWidgetManager,<br></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>int[] appWidgetIds) {<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>// TODO Auto-generated method stub<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>final int N = appWidgetIds.length;<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><br></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>// Perform this loop procedure for each App Widget that belongs to this provider<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>for (int i=0; i&lt;N; i++) {<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>int appWidgetId = appWidgetIds;<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>RemoteViews views=<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li>new RemoteViews(context.getPackageName(), R.layout.widgetlayout);<br> </li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>Intent UPintent=new Intent("zyf.test.widget.UP");<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>Intent DOWNintent=new Intent("zyf.test.widget.DOWN");<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>//实例化两个带有Action的Intent<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>PendingIntent pendingIntentUp<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li>=PendingIntent.getBroadcast(context, 0, UPintent, 0);<br> </li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>PendingIntent pendingIntentDown<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li>=PendingIntent.getBroadcast(context, 0, DOWNintent, 0);<br> </li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>//实例化两个以Intent来构造的PendingIntent<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>views.setOnClickPendingIntent(R.id.widget_BT_Up, pendingIntentUp);<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>views.setOnClickPendingIntent(R.id.widget_BT_Down, pendingIntentDown);<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>//给View上的两个按钮绑定事件,这里是广播消息的发送<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>appWidgetManager.updateAppWidget(appWidgetId, views);<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>}<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr> } </wbr></wbr></li> </ol> </div> </div> ②Widget自身消息接收,使用intent.getAction()来获取Action <div> <div> <ol> <li>@Override<br> </li> <li><wbr><wbr> public void onReceive(Context context, Intent intent) {<br></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>// TODO Auto-generated method stub<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>super.onReceive(context, intent);<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>if(intent.getAction().equals("zyf.test.widget.UP")){<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>Tag+=5;<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>if(Tag&gt;100){<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr> Tag=100;<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>}<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>views.setProgressBar(R.id.widget_ProgressBar, 100, Tag, false);<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>appManager.updateAppWidget(thisWidget, views);<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>}<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>if(intent.getAction().equals("zyf.test.widget.DOWN")){<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>Tag-=5;<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>if(Tag&lt;0){<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr> Tag=0;<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>}<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>views.setProgressBar(R.id.widget_ProgressBar, 100, Tag, false);<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr>appManager.updateAppWidget(thisWidget, views);<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>}<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr> } </wbr></wbr></li> </ol> </div> </div> ③进度条的进度值设置 <div> <div> <ol> <li>views.setProgressBar(R.id.widget_ProgressBar, 100, Tag, false);<br> </li> <li>//设置Widget上的进度条的进度值<br> </li> <li>//第一个参数,Widget上进度条ID<br> </li> <li>//第二个参数,进度条最大值<br> </li> <li>//第三个参数Tag,一个int值,就是设置的进度值<br> </li> <li>//第四个参数,是否是要进度条不确定 </li> </ol> </div> </div> 注意了,Widget自身的onReceive()方法如果要接收其他的Action广播。那就必须在Manifest中,在Intent-filter中添加Action: <div> <div> <ol> <li>&lt;receiver android:name="AppWidget"&gt;<br> </li> <li><wbr><wbr> &lt;intent-filter&gt;<br></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>&lt;action android:name="android.appwidget.action.APPWIDGET_UPDATE"&gt;&lt;/action&gt;<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr> &lt;action android:name="zyf.test.widget.UP"&gt;&lt;/action&gt;<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr><wbr> &lt;action android:name="zyf.test.widget.DOWN"&gt;&lt;/action&gt;<br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr> &lt;/intent-filter&gt;<br></wbr></wbr></li> <li><wbr><wbr> &lt;meta-data<br></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>android:resource="@xml/appwidget"<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr><wbr><wbr><wbr><wbr>android:name="android.appwidget.provider"&gt;<br></wbr></wbr></wbr></wbr></wbr></wbr></li> <li><wbr><wbr> &lt;/meta-data&gt;<br></wbr></wbr></li> <li>&lt;/receiver&gt; </li> </ol> </div> </div> </wbr></wbr></wbr></wbr>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值