android 自定义带关闭按钮的dialog

来源:互联网 发布:网络空间安全 科研 编辑:程序博客网 时间:2024/05/01 12:09
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了,希望对你有用!!


源码下载
0 0
原创粉丝点击