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();
发布了27 篇原创文章 · 获赞 24 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/shving/article/details/89538439