分享

自定义progressdialog

 aaie_ 2012-09-03

当执行某个操作需要耗时15秒以上,为了避免降低用户体验,可以使用进度条一类的UI控件。Android Framework提供了ProgressDialog,可以很好的解决这个问题。

ProgressDialog是AlertDialog的子类,有两种不同的表现形式。

第一种是针对没有明确的进度,不知道当前完成了多 少的情况,此时使用一个转动的圆环来展现;

第二种是针对有了明确的总进度,并知道当前的完成比例等信息,此时使用的是一个横条来展现。

但 是,如果特殊情况,因为由于设备的特性导致不能频繁刷新屏幕,即动画之类的效果统统禁用,系统的ProgressDialog也就不能使用了,可以修改 ProgressDialog的默认实现,使其不要频繁刷新。通过源代码可以知道,ProgressDiglog是通过在themes.xml定义 progressBarStyle,进一步从styles.xml中找到 Widget.ProgressBar的样式定义:

  1. <style name="Widget.ProgressBar">
  2.     <item name="android:indeterminateOnly">true</item>
  3.     <item name="android:indeterminateDrawable">@android:drawable/progress_medium</item>
  4.     <item name="android:indeterminateBehavior">repeat</item>
  5. </style>

如果没猜错的话,接下来要做事情就变成了修改android:indeterminateDrawable对应的drawable。

先向drawable文件夹下增加两个图片progress_round_1.png和progress_round_2.png,然后增加一个XML文件progress_round.xml。

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <animation-list
  3.         xmlns:android="http://schemas./apk/res/android"
  4.         android:oneshot="false">
  5.     <item android:drawable="@drawable/progress_round_1" android:duration="2000" />
  6.     <item android:drawable="@drawable/progress_round_2" android:duration="2000" />
  7. </animation-list>

这样不断转动的圆环变成了自己想要的图片。

接着增加相应的style:

  1. <style name="ProgressRound">
  2.     <item name="android:indeterminateDrawable">@drawable/progress_round</item>
  3. </style>

然后增加相应的theme:

  1. <style name="OppoTheme" parent="@android:style/Theme.Dialog.Alert">
  2.     <item name="android:progressBarStyle">@style/ProgressRound</item>
  3. </style>

最后来到生成Dialog的地方:

  1. @Override
  2.     protected Dialog onCreateDialog(int id) {
  3.         Log.d(TAG"onCreateDialog");
  4.  
  5.         switch (id) {
  6.             case PRODIALOG_KEY:
  7.                 mProDialog = new ProgressDialog(thisR.style.OppoTheme);
  8.                 mProDialog.setIndeterminate(true);
  9.                 mProDialog.setCancelable(true);
  10.                 return mProDialog;
  11.             default:
  12.                 return null;
  13.         }
  14.     }

Via[poemcode]

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约