效果图如下:
1.在drawable目录中创建border_radius_bg.xml:
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android" >
<gradient
android:angle="0"
android:endColor="#605cb85c"
android:startColor="#605cb85c" />
<corners android:radius="4dp" >
</corners>
</shape>
该drawable的用途是给组件绘制圆角边框半透明的背景,其中<corners android:radius="4dp" >指定圆角,
<gradient
android:angle="0"
android:endColor="#605cb85c"
android:startColor="#605cb85c" />
指定透明度为60的#5cb85c的颜色为背景。(#后8位数前两位为透明度,范围为0~ff,对应十进制就是0~255)
2.在layout目录中创建loading_dialog.xml:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="115dp"
android:layout_height="wrap_content"
android:orientation="vertical"
android:padding="10dp" >
<TextView
android:id="@+id/btnSltCntAll"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:background="@drawable/border_radius_bg"
android:gravity="left|center_vertical"
android:paddingBottom="5dp"
android:paddingLeft="10dp"
android:paddingTop="5dp"
android:text="全部联系人" >
</TextView>
</LinearLayout>
该layout的作用是给对话框布局,其中android:background="@drawable/border_radius_bg"为textview组件的背景指定为刚给出的圆角半透明背景
3.在value目录下创建styles.xml:
<resources xmlns:android="http://schemas.android.com/apk/res/android">
<style name="MyDialog" parent="@android:style/Theme.Dialog">
<item name="android:windowNoTitle">true</item>
<item name="android:background">#00000000</item>
<item name="android:windowBackground">@android:color/transparent</item>
</style>
</resources>
该style的作用是为整个dialog布置样式,其中<item name="android:background">#00000000</item>指定dialog的背景为全透明,
<item name="android:windowBackground">@android:color/transparent</item>指定dialog外面部分的背景为半透明.
4.编写java程序代码,实例化dialog:
Dialog dialog = new Dialog(RegisterActivity.this, R.style.MyDialog);
dialog.setContentView(R.layout.loading_dialog);
dialog.show();
总结:对话框的布局由layout指定,对话框外部和对话框的背景由style指定,且指定在java代码中进行。对话框内部组件的背景和圆角由drawable指定,指定在布局文件中进行.(对话框自身不用指定圆角,将最外层的内部元素指定为圆角即可)