android加载中对话框,循环,透明


1、自定义对话框
public class HkDialogLoading extends Dialog {
Context context;

ImageView vLoading; // 圆型进度条
Animation anim;// 动画

public HkDialogLoading(Context context) {
super(context, R.style.HKDialogLoading);
this.context = context;
}

public void onCreate(Bundle savedInstanceState) {
requestWindowFeature(Window.FEATURE_NO_TITLE);
requestWindowFeature(Window.PROGRESS_VISIBILITY_ON);
super.onCreate(savedInstanceState);

anim = AnimationUtils.loadAnimation(this.getContext(),
R.anim.rotate_repeat);
anim.setInterpolator(new LinearInterpolator());

vLoading = new ImageView(context);
vLoading.setImageResource(R.drawable.loading_icon);// 加载中的图片,建议圆形的

// 布局
FrameLayout.LayoutParams lp = new FrameLayout.LayoutParams(
FrameLayout.LayoutParams.MATCH_PARENT,
FrameLayout.LayoutParams.WRAP_CONTENT);
lp.gravity = Gravity.CENTER;

addContentView(vLoading, lp);

setCanceledOnTouchOutside(false);
}

@Override
public boolean onKeyDown(int keyCode, KeyEvent event) {
if (keyCode == KeyEvent.KEYCODE_BACK) {
// 按下了键盘上返回按钮
this.hide();
return true;
}
return false;
}

@Override
public void show() {
super.show();
vLoading.startAnimation(anim);
}
}

2、用到的动画文件rotate_repeat (在res/anim目录下面建文件rotate_repeat.xml)
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android"
android:interpolator="@android:anim/accelerate_interpolator" >
<rotate
android:duration="1000"
android:fromDegrees="0"
android:pivotX="50%"
android:pivotY="50%"
android:repeatCount="100"
android:repeatMode="restart"
android:toDegrees="360" />
</set>

3、用的到的样式文件 (在res/values目录下的style.xml文件中的<resources>节点下添加下面的代码)
<style name="HKDialogLoading" parent="@android:style/Theme.Dialog">
<item name="android:windowFrame">@null</item>
<item name="android:windowNoTitle">true</item>
<item name="android:windowBackground">@color/transparent</item>
<item name="android:windowIsFloating">true</item>
<item name="android:windowContentOverlay">@null</item>
</style>

4、调用
dialogLoading = new HKDialogLoading(this);
dialogLoading.show(); // 显示加载中对话框

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值