首先是一个工具类:
import android.app.Dialog;
import android.content.Context;
import android.os.Handler;
import android.view.animation.Animation;
import android.view.animation.AnimationUtils;
import android.widget.ImageView;
import com.zhiziyun.dmptest.bot.R;
/**
* Created by Administrator on 2017/11/28.
*/
public class MyDialog extends Dialog {
private Context context;
private static MyDialog dialog;
private ImageView ivProgress;
public MyDialog(Context context) {
super(context);
this.context = context;
}
public MyDialog(Context context, int themeResId) {
super(context, themeResId);
this.context = context;
}
//显示dialog的方法
public static MyDialog showDialog(Context context) {
dialog = new MyDialog(context, R.style.MyDialog);//dialog样式
dialog.setContentView(R.layout.dialog_layout);//dialog布局文件
dialog.setCanceledOnTouchOutside(false);//点击外部不允许关闭dialog
return dialog;
}
//10秒加载失败后自动关闭加载框并提示
public void SHOW() {
dialog.show();
Handler handler = new Handler();
handler.postDelayed(new Runnable() {
@Override
public void run() {
if (dialog != null && dialog.isShowing()) {
dialog.dismiss();
ToastUtils.showShort(context, "加载失败");
}
}
}, 10000);
}
@Override
public void onWindowFocusChanged(boolean hasFocus) {
super.onWindowFocusChanged(hasFocus);
if (hasFocus && dialog != null) {
ivProgress = (ImageView) dialog.findViewById(R.id.ivProgress);
Animation animation = AnimationUtils.loadAnimation(context, R.anim.dialog_progress_anim);
ivProgress.startAnimation(animation);
}
}
}
然后是样式:
<!-- dialog样式 -->
<style name="MyDialog" parent="@android:style/Theme.Dialog">
<item name="android:windowFrame">@null</item>
<item name="android:windowIsFloating">true</item>
<item name="android:windowIsTranslucent">false</item><!--半透明-->
<item name="android:windowNoTitle">true</item>
<item name="android:windowBackground">@android:color/transparent</item>
<item name="android:backgroundDimEnabled">false</item>
<item name="android:backgroundDimAmount">0.6</item>
</style>
接下来是dialog的布局:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerInParent="true"
android:gravity="center"
android:background="@drawable/shape_dialog"
android:orientation="vertical"
android:padding="15dp">
<RelativeLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center">
<ImageView
android:id="@+id/ivProgress"
android:layout_width="50dp"
android:layout_height="50dp"
android:layout_centerInParent="true"
android:background="@drawable/progress" />
</RelativeLayout>
<TextView
android:id="@+id/tvText"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="5dp"
android:text="加载中,请稍后..."
android:textColor="@color/white"
android:textSize="16sp" />
</LinearLayout>
</RelativeLayout>
dialog的背景用到了shape_dialog,目的是为背景设置透明度:
<?xml version="1.0" encoding="UTF-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_pressed="false">
<shape android:shape="rectangle" >
<!-- 填充的颜色 前两位是透明度-->
<solid android:color="#A5000000"></solid>
<!-- 设置按钮的四个角为弧形 -->
<!-- android:radius 弧形的半径 -->
<corners android:radius="8dip" />
<!-- padding:Button里面的文字与Button边界的间隔 -->
<padding android:bottom="2dp" android:left="2dp" android:right="2dp" android:top="2dp" />
</shape>
</item>
</selector>
至于透明度设置成百分之多少根据大家需求设置,只需要替换掉下面代码的前两位就行了“A5”
<solid android:color="#A5000000"></solid>
那么百分之几对应什么数值呢?给大家推荐一篇博客,对照上面设置就行了。
使用的时候先声明这个类
private MyDialog dialog;
然后在需要显示加载框的地方写上
dialog = MyDialog.showDialog(this);
dialog.SHOW();
最后隐藏加载框
dialog.dismiss();