android 自定义带关闭按钮的dialog

本文介绍如何在Android应用中自定义一个带有关闭按钮的Dialog,通过创建自定义布局、设置样式以及编写Dialog类实现点击按钮关闭Dialog的效果。提供完整代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

android 自定义带关闭按钮的dialog
  在android的开发过程中,使用android常用的那几种dialog样式是远远不够的,不符合设计给出的设计图,尤其是右上角带有关闭按钮的dialog,之前一直都没有太在意这方面的,但是在实际的项目中,遇到了,上网查了一些资料,但是很少,而且觉得有点复杂,因此按照自己的理解实现了,效果图如下:


主要是在自定义的dialog.xml布局文件上,多的不说了,直接上代码吧:

  1、dialog.xml

<?xml version="1.0" encoding="utf-8"?>
    <FrameLayout  xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="match_parent" 
        android:layout_height="wrap_content"
        android:background="@android:color/transparent">


        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:orientation="vertical" 
            android:layout_margin="10dip"
            android:background="#ffffff">


            <TextView
                android:id="@+id/textView1"
                android:layout_width="fill_parent"
                android:layout_height="wrap_content"
                android:text="文字描述" 
                 android:layout_margin="10dip"/>


            <LinearLayout
                android:id="@+id/textView2"
                android:layout_width="fill_parent"
                android:layout_height="0.25dp"
               android:background="#cccccc"/>


            <RelativeLayout
                android:layout_width="match_parent"
                android:layout_height="150dip" >


                <RatingBar
                    android:id="@+id/ratingBar1"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:layout_centerHorizontal="true"
                    android:layout_centerVertical="true" />


                <TextView
                    android:id="@+id/textView3"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:layout_above="@+id/ratingBar1"
                    android:layout_centerHorizontal="true"
                    android:text="这是进度条" />


            </RelativeLayout>


        </LinearLayout>
        
          <ImageView
                android:id="@+id/close"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:src="@drawable/close"
                android:layout_gravity="top|right" />

    </FrameLayout>

 2、style样式

<!-- dialog样式 -->
    <style name="MyDialog" parent="@android:Theme.Dialog">
        <item name="android:windowFrame">@null</item>
        <item name="android:windowNoTitle">true</item>
        <item name="android:windowBackground">@android:color/transparent</item>
        <item name="android:windowIsFloating">true</item>
        <item name="android:windowContentOverlay">@null</item>
    </style>


 3、自定义的dialog类MyDialog.xml

package com.lly.cn;


import android.app.Dialog;
import android.content.Context;
import android.content.DialogInterface;
import android.os.Bundle;
import android.view.View;
import android.widget.ImageView;


public class MyDialog extends Dialog{
ImageView img_back;
Context context;
public MyDialog(Context context, int theme) {
super(context, theme);
// TODO Auto-generated constructor stub
this.context=context;
}
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
this.setContentView(R.layout.dialog);

initview();
}
private void initview() {
// TODO Auto-generated method stub
img_back=(ImageView) findViewById(R.id.close);
img_back.setOnClickListener(new View.OnClickListener() {

public void onClick(View v) {
MyDialog.this.dismiss();
}
});
}
}

 4、自定义dialog的使用

只要在你想用的地方加上这几句就可以
        mydialog=new MyDialog(MainActivity.this,R.style.MyDialog);
mydialog.show();
mydialog.setCancelable(false);   //点击dialog以外的地方dialog不消失,可根据自己的需要来改咯

这样就可以完成自定义带关闭按钮的dialog了,希望对你有用!!


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值