android自定义按钮弹出窗关闭按钮,android 自定义带关闭按钮的dialog

android 自定义带关闭按钮的dialog

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

f0f1c243b01bfab5d989cd37ac72cf18.png

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

1、dialog.xml

android:layout_width="match_parent"

android:layout_height="wrap_content"

android:background="@android:color/transparent">

android:layout_width="match_parent"

android:layout_height="wrap_content"

android:orientation="vertical"

android:layout_margin="10dip"

android:background="#ffffff">

android:id="@+id/textView1"

android:layout_width="fill_parent"

android:layout_height="wrap_content"

android:text="文字描述"

android:layout_margin="10dip"/>

android:id="@+id/textView2"

android:layout_width="fill_parent"

android:layout_height="0.25dp"

android:background="#cccccc"/>

android:layout_width="match_parent"

android:layout_height="150dip" >

android:id="@+id/ratingBar1"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:layout_centerHorizontal="true"

android:layout_centerVertical="true" />

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="这是进度条" />

android:id="@+id/close"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:src="@drawable/close"

android:layout_gravity="top|right" />

2、style样式

@null

true

@android:color/transparent

true

@null

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、付费专栏及课程。

余额充值