Android制作一个简洁的自定义ProgressDialog

ProgressDialog是安卓应用中常见的交互控件,在有网络请求的地方经常会使用到。如何自定义一个progress dialog是最基本的了,今天就制作一个简洁的ProgressDialog模板,以后可以直接拿过去修改成自己的风格,先看效果图:

首先写一个dialog的布局文件

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@android:color/transparent">

    <RelativeLayout
        android:layout_width="100dp"
        android:layout_height="100dp"
        android:layout_centerInParent="true"
        android:background="@drawable/loading_bg"
        android:padding="15dp">

        <LinearLayout
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_centerInParent="true"
            android:gravity="center"
            android:orientation="vertical">

            <ProgressBar
                android:id="@+id/progressBar1"
                style="?android:attr/progressBarStyleLarge"
                android:layout_width="30dip"
                android:layout_height="30dip" />

            <TextView
                android:id="@+id/tv_message"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_marginTop="10dp"
                android:maxLines="1"
                android:text="@string/request_loading_info"
                android:textColor="#fff"
                android:textSize="14sp" />
        </LinearLayout>

    </RelativeLayout>

</RelativeLayout>

然后新建一个CustomProgressDialog继承于Dialog

public class CustomProgressDialog extends Dialog {

    public TextView messageTv;

	public CustomProgressDialog(Context context) {
		this(context, R.style.MyDialogStyle, "");
	}

	public CustomProgressDialog(Context context, String string) {
		this(context, R.style.MyDialogStyle, string);
	}

	public CustomProgressDialog(Context context, int theme, String string) {
		super(context, theme);
		setCanceledOnTouchOutside(false);
		setContentView(R.layout.custom_progress_dialog);
		messageTv = (TextView) findViewById(R.id.tv_message);
		messageTv.setText(string);
		getWindow().getAttributes().gravity = Gravity.CENTER;
		getWindow().getAttributes().dimAmount = 0f;
	}

	@Override
	public void dismiss() {
		super.dismiss();
	}

}

上面构造方法用到了一个MyDialogStyle的theme, 在自定义dialog中,需要自定义dialog的样式,所以还需要在styles.xml中写一个dialog样式:

<!-- dialog样式 -->
    <style name="MyDialogStyle">
        <item name="android:windowBackground">@android:color/transparent</item>
        <item name="android:windowFrame">@null</item>
        <item name="android:windowNoTitle">true</item>
        <item name="android:windowIsFloating">true</item>
        <item name="android:windowIsTranslucent">true</item>
        <item name="android:windowContentOverlay">@null</item>
        <item name="android:windowAnimationStyle">@android:style/Animation.Dialog</item>
        <item name="android:backgroundDimEnabled">true</item>
    </style>

样式中的各属性的含义,看英文名就应该能知道是什么意思了,其中android:backgroundDimEnabled是表示dialog弹出时,背景要不要变暗。如果想改变转圈的图标颜色,可以使用

android:indeterminateTint="@color/white_color"

android:indeterminateTintMode="src_atop"

不过这两个属性只在5.0以上的版本生效,比如我们修改为绿色:

            <ProgressBar
                android:id="@+id/progressBar1"
                style="?android:attr/progressBarStyleLarge"
                android:layout_width="30dip"
                android:layout_height="30dip"
                android:indeterminateTint="@color/color_1CCA8F"
                android:indeterminateTintMode="src_atop"/>

 

这样一个简单的ProgressDialog就做完了,使用的时候可以这样使用:

CustomProgressDialog customProgressDialog = new CustomProgressDialog(this, "登录中...");
customProgressDialog.show();

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值