zoukankan      html  css  js  c++  java
  • 自定义Dialog之Progress(二)

    自定义Dialog之Progress(二)

    系统的Dialog一般是适合UI设计的需求,那么就需要自定义的ProgressDialog.

    第一想法就是能在应用级别全局改变应用的ProgressDialog的样式。(已经试过,没有成功)做法是:
    <item name="android:progressBarStyle">@style/theme.customer_progress_dialog</item>

    @style/theme.customer_progress_dialog 是自定义的theme

    如果有成功的,希望能分享下,谢谢。


    第二种做法是自定义theme, 然后定义一个ProgressDialog:CustomProgressDialog. 在应用里面就用这个.

    自定义theme:

    <style name="theme.customer_progress_dialog" parent="@android:style/Theme.Dialog">
             <item name="android:alertDialogStyle">@style/customer_progress_dialog</item>
             <item name="android:progressBarStyleSmall">@style/customer_progress_dialog</item>
             <item name="android:windowBackground">@android:color/transparent</item>
             <item name="android:windowNoTitle">true</item>
             <item name="android:windowIsTranslucent">true</item>
             <item name="android:paddingLeft">10dip</item>  //图片与左边距的距离
             <item name="android:paddingRight">10dip</item> //message与右边距的距离
             <item name="android:textSize">20sp</item>      //message字体的大小
             <item name="android:textColor">@android:color/white</item>  //message字体的颜色
         </style>

    @style/customer_progress_dialog 自定义的ProgressDialog style

    <style name="customer_progress_dialog" parent="@android:style/Widget.ProgressBar">
              <item name="android:indeterminateDuration">2000</item>
    	  <item name="android:fullDark">@drawable/tip2_bg</item>
              <item name="android:topDark">@drawable/tip2_bg</item>
              <item name="android:centerDark">@drawable/tip2_bg</item>
              <item name="android:bottomDark">@drawable/tip2_bg</item>
              <item name="android:fullBright">@drawable/tip2_bg</item>
              <item name="android:topBright">@drawable/tip2_bg</item>
              <item name="android:centerBright">@drawable/tip2_bg</item>
              <item name="android:bottomBright">@drawable/tip2_bg</item>
              <item name="android:bottomMedium">@drawable/tip2_bg</item>
              <item name="android:centerMedium">@drawable/tip2_bg</item>
         </style>

    自定义的CustomProgressDialog:

    package com.example.android;
    
    import android.app.ProgressDialog;
    import android.content.Context;
    import android.os.Bundle;
    
    public class CustomeProgressDialog extends ProgressDialog {
    
        private Context mContent ;
        
        public CustomeProgressDialog(Context context){
    	super(context,R.style.theme_customer_progress_dialog) ;
    	mContent = context ;
        }
        
        public CustomeProgressDialog(Context context, int theme) {
    	super(context, theme);
        }
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            this.setIndeterminateDrawable(mContent.getResources().getDrawable(R.drawable.customer_progess_dialog)) ;
            this.setCanceledOnTouchOutside(false) ;
        }
        
        
        public static CustomeProgressDialog show(Context context,String message){
    	 CustomeProgressDialog dialog = new CustomeProgressDialog(context) ;
             dialog.setMessage(message) ;
             dialog.show() ;
             return dialog ;
        }
    }
    


    测试代码:

    CustomeProgressDialog.show(this,"上传数据中") ;

    结果:





























  • 相关阅读:
    subset子集全排序问题
    第15章动态规划------算法导论
    内存管理思维导图------现代操作系统(第四版)
    进程与线程思维导图------现代操作系统(第四版)
    现代操作系统
    GHUnitiOS 单元测试(带UI界面)下载地址
    iOS + webSocket 通讯
    iOS 甘特图的实现
    NSDate根据日期获得当前是周几,以及一年内的第几周,以及一个月内得第几周
    Swift 中文文档
  • 原文地址:https://www.cnblogs.com/java20130722/p/3207243.html
Copyright © 2011-2022 走看看