Android 自定义dialog

1.MainActivity.java

package com.future.test;

import android.app.Activity;
import android.app.Dialog;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;

public class MainActivity extends Activity {
	@Override
	public void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);
		Button button = (Button) findViewById(R.id.button1);
		button.setOnClickListener(new OnClickListener() {

			@Override
			public void onClick(View v) {
				// 初始化一个自定义的Dialog
				Dialog dialog = new MyDialog(MainActivity.this,R.style.MyDialog);
				dialog.show();
			}
		});
	}
}

2. values下的style.xml

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <style name="MyDialog" parent="@android:Theme.Dialog">
        <item name="android:windowFrame">@null</item>
        <item name="android:windowNoTitle">true</item> 
        <item name="android:windowBackground">@drawable/col_opacity_0</item>
        <item name="android:windowIsFloating">true</item>
        <item name="android:windowContentOverlay">@null</item>
    </style>
</resources>

3.Mydialog类继承dialog

package com.future.test;

import android.app.Dialog;
import android.content.Context;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.Toast;

public class MyDialog extends Dialog implements OnClickListener{
	
	private Context context;

	public MyDialog(Context context, int theme) {
		super(context, theme);
		this.context = context;
	}

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		this.setContentView(R.layout.dialog);
		
		Button mButtonOk = (Button) this.findViewById(R.id.dialog_button_ok);
		mButtonOk.setOnClickListener(this);
		Button mButtonCancel = (Button) this.findViewById(R.id.dialog_button_cancel);
		mButtonCancel.setOnClickListener(this);
	}

	@Override
	public void onClick(View v) {
		switch(v.getId())
		{
		case R.id.dialog_button_ok:
			this.showToast("确定");
			break;
		case R.id.dialog_button_cancel:
			this.showToast("取消");
			this.dismiss();
			break;
		}
	}
	
	private void showToast(String text)
	{
		Toast.makeText(this.context, text, Toast.LENGTH_LONG).show();
	}
}
4. Mydialog里面的dialog.xml布局

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:layout_marginLeft="20dp"
    android:layout_marginRight="20dp">
    <RelativeLayout 
    	android:layout_width="fill_parent"
    	android:layout_height="wrap_content"
    	android:paddingTop="10dp"
    	android:paddingBottom="10dp"
    	android:background="#18517B" >
    	<TextView 
    		android:layout_width="fill_parent"
	    	android:layout_height="wrap_content" 
	    	android:gravity="center"
	    	android:textSize="20sp"
	    	android:textColor="#ffffff"
	    	android:text="确认退出" />
    </RelativeLayout>
    <!-- 间隔线
    <TextView android:layout_width="fill_parent"
    	android:layout_height="1dp"
    	android:background="@drawable/lins"/>
     -->
    <RelativeLayout 
    	android:layout_width="fill_parent"
    	android:layout_height="wrap_content" 
    	android:paddingTop="20dp"
    	android:background="#ffffff">
    	<TextView 
    		android:id="@+id/quit_true"
    		android:layout_width="fill_parent"
    		android:layout_height="wrap_content"
    		android:text="确定要退出游戏吗?"
    		android:textSize="20sp"
    		android:textColor="#000000"
    		android:gravity="center" />
    	<RelativeLayout 
    		android:layout_width="fill_parent"
    		android:layout_height="wrap_content" 
    		android:layout_centerInParent="true" 
    		android:layout_below="@id/quit_true"  
    		android:paddingTop="20dp"
    		android:paddingLeft="30dp"
    		android:paddingRight="30dp"
    		android:paddingBottom="20dp">
    		<Button 
	            android:id="@+id/dialog_button_ok" 
	            android:layout_width="wrap_content"  
	            android:layout_height="wrap_content" 
	            android:background="@drawable/selor"
	            android:layout_alignParentLeft="true"
	            android:text="确定"/>
	        <Button 
	            android:id="@+id/dialog_button_cancel" 
	            android:layout_width="wrap_content"
	            android:layout_height="wrap_content"
	            android:layout_alignParentRight="true" 
	            android:background="@drawable/selor"  
	            android:text="取消"/>
    	</RelativeLayout>
    </RelativeLayout>
</LinearLayout>


5. main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical" android:layout_width="fill_parent"
    android:layout_height="fill_parent">
    <Button 
        android:text="显示自定义Dialog" 
        android:id="@+id/button1"
        android:layout_height="wrap_content" 
        android:layout_width="fill_parent"/>
</LinearLayout>

6. 在处理按钮的颜色按下变色的时候,我定义一个selor.xml文件来变换它,但是不起作用,我有在selor.xml里面又用到了一个btn_style.xml文件才能起到作用,不知道怎么回事要套两层

selor.xml文件

<?xml version="1.0" encoding="utf-8"?>
<selector 
 xmlns:android="http://schemas.android.com/apk/res/android"> 
	<item android:state_selected="true" android:drawable="@drawable/btn_style"/> 
    <item android:drawable="@drawable/btn_style"/> 
</selector>

btn_style.xml文件

<?xml version="1.0" encoding="utf-8" ?> 
<selector xmlns:android="http://schemas.android.com/apk/res/android">
	<item android:state_pressed="true" android:drawable="@drawable/btn_bg_pressed"/>
	<item android:drawable="@drawable/btn_bg"/>
</selector>


项目源码下载地址




  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android自定义dialog是一种可以根据开发者的需求进行自定义的对话框。通过自定义dialog,开发者可以实现特定的界面设计和功能。根据引用,我们可以使用AlertDialog.Builder来创建一个普通的弹出框。而根据引用,我们可以通过简单的设置和技巧来实现Android自定义dialog。如果想要对话框具有自定义布局,可以创建一个布局文件,然后通过调用AlertDialog.Builder的setView()方法将其添加到对话框中。默认情况下,自定义布局会填充对话框窗口,但是仍然可以使用AlertDialog.Builder的其他方法来添加按钮和标题。此外,开发者还可以完全自定义一个Dialog,需要进行以下几步: 1. 定义一个style 2. 创建一个继承自Dialog的子类 3. 在子类中实现自定义布局和相关功能 4. 在应用中调用自定义dialog的实例来显示对话框。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [android自定义Dialog](https://blog.csdn.net/weixin_41796401/article/details/96636408)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [Android自定义dialog简单实现方法](https://download.csdn.net/download/weixin_38736562/12800768)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值