该圆形进度条没有数字,只有一个加载中显示。
定义一个进度条的xml文件,loading.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="100dp"
android:layout_height="100dp"
android:layout_gravity="center_horizontal"
android:background="@drawable/shape_dialog_bg"
android:layout_centerInParent="true"
android:orientation="vertical">
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="10dp">
<ProgressBar
android:id="@+id/pb_load"
android:layout_width="65dp"
android:layout_height="65dp"
android:indeterminateDrawable="@drawable/progressbar"
android:layout_centerInParent="true"/>
</RelativeLayout>
<TextView
android:id="@+id/tv_load_dialog"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:text="加载中..."
android:textColor="#9a9b98"
android:textSize="12sp"/>
</LinearLayout>
其中定义了一个黑色的背景shape_dialog_bg.xml,一个加载旋转的动画progressbar.xml
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android" >
<corners android:radius="8dp" />
<solid android:color="#88000000" />
</shape>
<?xml version="1.0" encoding="utf-8"?>
<animated-rotate xmlns:android="http://schemas.android.com/apk/res/android"
android:fromDegrees="0"
android:pivotX="50%"
android:pivotY="50%"
android:toDegrees="720">
<shape
android:innerRadiusRatio="3"
android:shape="ring"
android:thicknessRatio="15"
android:useLevel="false">
<gradient
android:centerColor="#c6c6c6"
android:centerY="0.50"
android:endColor="#c6c6c6"
android:startColor="#55c6c6c6"
android:type="sweep"
android:useLevel="false" />
</shape>
</animated-rotate>
然后定义一个Loading_view的类,用于生成进度条供其他类调用
public class Loading_view extends ProgressDialog {
public Loading_view(Context context) {
super(context);
}
public Loading_view(Context context, int theme) {
super(context, theme);
}
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
init(getContext());
}
private void init(Context context) {
setCancelable(true);
setCanceledOnTouchOutside(false);
setContentView(R.layout.loading);//loadingµÄxmlÎļþ
WindowManager.LayoutParams params = getWindow().getAttributes();
params.width = WindowManager.LayoutParams.WRAP_CONTENT;
params.height = WindowManager.LayoutParams.WRAP_CONTENT;
getWindow().setAttributes(params);
}
@Override
public void show() {
super.show();
}
@Override
public void dismiss() {
super.dismiss();
}
}
在MainActivity中调用Loading_view 显示一个进度条
public class QulityEventActivity extends Activity {
private Loading_view loadingProressBar;//申明一个实例
/*
*
*
*
*
*/
private void showProcess() {
loadingProressBar = new Loading_view(this, R.style.CustomDialog);//实例化
loadingProressBar.show();//显示
}
public void dissProgressBar() {
loadingProressBar.dismiss();//取消显示
}
}
直接调用showProcess函数就能使用
其中R.style.CustomDialog,是自定义的样式
<style name="CustomDialog" parent="@android:style/Animation.Dialog">
<item name="android:backgroundDimEnabled">false</item>
<item name="android:windowBackground">@android:color/transparent</item>
</style>