第一種:使用Activity來實現自定義對話框。
1. 定義根布局是RelativeLayout。
2. 定義主布局在根布局的中間,需要設定屬性centerInParent=”true”。
具體見sms_confirm_dialog.xml解析。
代碼片段:
public class ConfirmActivity extends BaseActivity {
protected void onCreate(android.os.Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
requestWindowFeature(Window.FEATURE_NO_TITLE);
setContentView(R.layout.sms_confirm_dialog);
}
}
Intent it = new Intent(mContext, ConfirmActivity.class);
startActivityForResult(it, TxrjConstant.REQUEST_CONFIRM);
背景全為黑是怎么回事?
修改setContentView之后背景仍然是黑色。
View view = LayoutInflater.from(this).inflate(R.layout.sms_confirm_dialog, null);
view.getBackground().setAlpha(10);
setContentView(view);
設定theme之后竟然會多了灰色的邊框出來,邊框內部是黑色填充。
setTheme(android.R.style.Theme_Dialog);
參考:http://blog.csdn.net/tianshuguang/article/details/6898355
在Manifest.xml文件中設定android:theme竟然讓黑色背景消失了,只留下黑色的邊框。
<activity android:name=".activity.ConfirmActivity"
android:theme="@android:style/Theme.Dialog"/>
修改android:theme,改為如下,然后就不再出現黑色邊框。
<activity android:name=".activity.ConfirmActivity"
android:theme="@style/dialog_translucent"/>
<style name="dialog_translucent" parent="@android:style/Theme.Dialog">
<item name="android:windowBackground">@color/translucent_background</item>
<item name="android:windowIsTranslucent">true</item>
<item name="android:windowNoTitle">true</item>
<item name="android:windowAnimationStyle">@+android:style/Animation.Translucent</item>
</style>
雖然實現了對話框。但是點擊半透明的位置,window會自動關閉。
查看android對系統樣式Theme.Dialog的定義,找到屬性windowCloseOnTouchOutside與此有關。
將它的值在dialog_translucent重新設定為false。
<item name="android:windowCloseOnTouchOutside">false</item>
android系統對樣式Theme.Dialog的定義。
<style name="Theme.Dialog">
<item name="android:windowFrame">@null</item>
<item name="android:windowTitleStyle">@android:style/DialogWindowTitle</item>
<item name="android:windowBackground">@android:drawable/panel_background</item>
<item name="android:windowIsFloating">true</item>
<item name="android:windowContentOverlay">@null</item>
<item name="android:windowAnimationStyle">@android:style/Animation.Dialog</item>
<item name="android:windowSoftInputMode">stateUnspecified|adjustPan</item>
<item name="android:windowCloseOnTouchOutside">@bool/config_closeDialogWhenTouchOutside</item>
<item name="android:windowActionModeOverlay">true</item>
<item name="android:colorBackgroundCacheHint">@null</item>
<item name="textAppearance">@android:style/TextAppearance</item>
<item name="textAppearanceInverse">@android:style/TextAppearance.Inverse</item>
<item name="textColorPrimary">@android:color/primary_text_dark</item>
<item name="textColorSecondary">@android:color/secondary_text_dark</item>
<item name="textColorTertiary">@android:color/tertiary_text_dark</item>
<item name="textColorPrimaryInverse">@android:color/primary_text_light</item>
<item name="textColorSecondaryInverse">@android:color/secondary_text_light</item>
<item name="textColorTertiaryInverse">@android:color/tertiary_text_light</item>
<item name="textColorPrimaryDisableOnly">@android:color/primary_text_dark_disable_only</item>
<item name="textColorPrimaryInverseDisableOnly">@android:color/primary_text_light_disable_only</item>
<item name="textColorPrimaryNoDisable">@android:color/primary_text_dark_nodisable</item>
<item name="textColorSecondaryNoDisable">@android:color/secondary_text_dark_nodisable</item>
<item name="textColorPrimaryInverseNoDisable">@android:color/primary_text_light_nodisable</item>
<item name="textColorSecondaryInverseNoDisable">@android:color/secondary_text_light_nodisable</item>
<item name="textColorHint">@android:color/hint_foreground_dark</item>
<item name="textColorHintInverse">@android:color/hint_foreground_light</item>
<item name="textColorSearchUrl">@android:color/search_url_text</item>
<item name="textAppearanceLarge">@android:style/TextAppearance.Large</item>
<item name="textAppearanceMedium">@android:style/TextAppearance.Medium</item>
<item name="textAppearanceSmall">@android:style/TextAppearance.Small</item>
<item name="textAppearanceLargeInverse">@android:style/TextAppearance.Large.Inverse</item>
<item name="textAppearanceMediumInverse">@android:style/TextAppearance.Medium.Inverse</item>
<item name="textAppearanceSmallInverse">@android:style/TextAppearance.Small.Inverse</item>
<item name="listPreferredItemPaddingLeft">10dip</item>
<item name="listPreferredItemPaddingRight">10dip</item>
</style>
定義樣式的文件所在位置:
android-sdk-windows\platforms\android-16\data\res\values\themes.xml
第二種:使用Dialog來實現自定義對話框。
private void confirm() {
Dialog dialog = new Dialog(this, R.style.dialog);
dialog.setContentView(R.layout.sms_confirm_dialog);
dialog.setCancelable(true);
dialog.show();
}
在onBackPressed()方法中調用
confirm();
注意:不要執行super.onBackPressed()方法,否則點擊back鍵就返回到上一個界面。
需要在values/styles.xml文件中定義
<style name="dialog" parent="@android:style/Theme.Dialog">
<item name="android:windowFrame">@null</item>
<item name="android:windowIsFloating">true</item>
<item name="android:windowIsTranslucent">true</item>
<item name="android:windowNoTitle">true</item>
<item name="android:background">@android:color/transparent</item>
<item name="android:windowBackground">@android:color/transparent</item>
<item name="android:backgroundDimEnabled">true</item>
<item name="android:backgroundDimAmount">0.6</item>
</style>
解析sms_confirm_dialog.xml文件
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:background="#00000000"
android:layout_width="match_parent"
android:layout_height="match_parent" >
<LinearLayout
android:layout_centerInParent="true" // 在屏幕的中間
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="180dip"
android:background="#00000000" // 透明的背景
android:layout_marginLeft="10dip"
android:layout_marginRight="10dip">
<FrameLayout
android:background="@drawable/dialog_title"
android:layout_width="match_parent"
android:layout_height="50dip">
<TextView
android:text="alert"
android:textSize="16dip"
android:textColor="@color/white"
android:layout_gravity="center" // TextView控件位於FrameLayout的中間
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@android:color/transparent"/> // 透明的背景
</FrameLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="0dip"
android:layout_weight="1"
android:background="@color/white">
<TextView
android:text="No valid recipient, do you abort?"
android:textSize="16dip"
android:textColor="@color/black"
android:gravity="center_vertical" // 將文字顯示在TextView的垂直方向的中間
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingLeft="10dip"
android:paddingRight="10dip"
android:background="@color/white"/>
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="50dip"
android:orientation="vertical"
android:background="@android:color/transparent">
<TextView
android:layout_width="match_parent"
android:layout_height="1dip" // 使用顏色來定義單色橫線
android:background="#999999"/>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="50dip"
android:orientation="horizontal"
android:background="@android:color/transparent">
<TextView
android:text="Yes"
android:textSize="16dip"
android:textColor="@color/black"
android:gravity="center" // 將文字顯示在TextView的中間
android:layout_width="0dip"
android:layout_weight="1" // 伸縮充滿剩余空間
android:layout_height="match_parent"
android:background="#CCCCCC"/>
<TextView
android:layout_width="1dip" // 使用顏色來定義單色豎線
android:layout_height="match_parent"
android:background="#999999"/>
<TextView
android:text="No"
android:textSize="16dip"
android:textColor="@color/black"
android:gravity="center" // 將文字顯示在TextView的中間
android:layout_width="0dip"
android:layout_weight="1" // 伸縮充滿剩余空間
android:layout_height="match_parent"
android:background="#CCCCCC"/>
</LinearLayout>
</LinearLayout>
</LinearLayout>
</RelativeLayout>