android 继承dialog自定义对话框
android ?繼承dialog自定義對話框
樣式如下:
代碼實現:
主要Activity:
public class MainActivity extends Activity {
Button button;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
button = (Button)findViewById(R.id.show_dialog);
button.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
new MyDialog(MainActivity.this,R.style.my_dialog_theme).show();
}
});
}
}
注意:要為定義的dialog設置theme,否則顯示的dialog外邊有白色邊框:
theme的定義如下:
打開stytle.xml文件(values目錄下),加入如下代碼:
<style name="my_dialog_theme" parent="@android:Theme.Dialog">
? ? ? ? ?<item name="android:windowFrame">@null</item>
? ? ? ? <item name="android:windowNoTitle">true</item>?
? ? ? ? <item name="android:windowBackground">@drawable/dialog_bg</item> ? ?//這句話不能少,否則dialog會出現黑色邊框
? ? ? ? <item name="android:windowIsFloating">true</item>
? ? ? ? <item name="android:windowContentOverlay">@null</item>
? ? </style>
主要布局文件:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
? ? xmlns:tools="http://schemas.android.com/tools"
? ? android:layout_width="match_parent"
? ? android:layout_height="match_parent"
? ? tools:context=".MainActivity" >
? ? <Button android:id="@+id/show_dialog"
? ? ? ? android:layout_width="wrap_content"
? ? ? ? android:layout_height="wrap_content"
? ? ? ? android:layout_centerHorizontal="true"
? ? ? ? android:layout_centerVertical="true"
? ? ? ? android:text="showDialog" />
</RelativeLayout>
自定義dialog代碼:
public class MyDialog extends Dialog{
public Button button_yes;
public Button button_no;
public MyDialog(Context context) {
super(context);
}
public MyDialog(Context context, int theme) {
super(context, theme);
}
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.dialog);
button_yes = (Button)findViewById(R.id.button_yes);
button_no = (Button)findViewById(R.id.button_no);
addButtonYesListener();
addButtonNoListener();
}
public void addButtonYesListener(){
button_yes.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
MyDialog.this.dismiss();
}
});
}
public void addButtonNoListener(){
button_no.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
MyDialog.this.dismiss();
}
});
}
}
dialog布局文件:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
? ? xmlns:tools="http://schemas.android.com/tools"
? ? android:layout_width="wrap_content"
? ? android:layout_height="wrap_content"
? ? android:background="@drawable/dialog_bg"
? ? android:orientation="vertical"
? ? tools:context=".MainActivity" >
? ? <LinearLayout android:layout_width="fill_parent"
? ? ? ? android:layout_height="wrap_content"
? ? ? ? android:gravity="center">
? ? ? ?
? ? ? ? <TextView android:layout_width="wrap_content"
? ? ? ? ? ? android:layout_height="wrap_content"
? ? ? ? ? ?android:layout_marginTop="15dp"
? ? ? ? ? ?android:layout_marginBottom="5dp"
? ? ? ? ? ? android:text="這是一個自定義對話框"
? ? ? ? ? ? android:textColor="#FF3271"/>
? ? </LinearLayout>
? ? <View android:layout_width="300dp"
? ? ? ? android:layout_height="2dp"
? ? ? ? android:background="@drawable/dialog_line"/>
? ? <RelativeLayout android:layout_width="fill_parent"
? ? ? ? android:layout_height="wrap_content"
? ? ? ? android:layout_marginTop="20dp">
? ? ? ??
? ? ? ? <Button android:id="@+id/button_yes"
? ? ? ? ? ? android:layout_width="wrap_content"
? ? ? ? ? ? android:layout_height="wrap_content"
? ? ? ? ? ? android:text="確定"
? ? ? ? ? ? android:background="@drawable/button_click_sector"
? ? ? ? ? ? android:layout_alignParentLeft="true"
? ? ? ? ? ? android:layout_marginLeft="10dp"/> ? ? ? ?
? ? ? ? <Button android:id="@+id/button_no"
? ? ? ? ? ? android:layout_width="wrap_content"
? ? ? ? ? ? android:layout_height="wrap_content"
? ? ? ? ? ? android:text="取消"
? ? ? ? ? ? android:background="@drawable/button_click_sector"
? ? ? ? ? ? android:layout_alignParentRight="true"
? ? ? ? ? ? android:layout_marginRight="10dp"/>
? ? </RelativeLayout>??
</LinearLayout>
用到的圖片資源:
???
demo下載地址:
總結
以上是生活随笔為你收集整理的android 继承dialog自定义对话框的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: android 使用xml布局自己的对话
- 下一篇: FireWork 制作android