zoukankan      html  css  js  c++  java
  • Android自定义Dialog

    转自:http://www.cnblogs.com/and_he/archive/2011/09/16/2178716.html

    先来一张图吧,很简单,只有一个Activity,当点击Button的时候就弹出这个自定义的Dialog

    里面的几张图都比较丑,我不多会美工,随便用powerpoint画了几张图,原理是一样的,先不计较这些。下面正入正题

    为了照顾到所有的码农,在些把所有的代码都贴出来

    新建工程在此就不贴出来了,只是为了方便大家的复制粘贴,取包名为com.and.mydialog,主Activity取名为MyDialogActivity

    复制代码
    package com.and.mydialog;

    import android.app.Activity;
    import android.app.AlertDialog;
    import android.app.Dialog;
    import android.content.DialogInterface;
    import android.os.Bundle;
    import android.view.KeyEvent;
    import android.view.LayoutInflater;
    import android.view.Menu;
    import android.view.MenuItem;
    import android.view.View;
    import android.view.View.OnClickListener;
    import android.widget.Button;
    import android.widget.Toast;

    publicclass MyDialogActivity extends Activity {
    /** Called when the activity is first created. */
    @Override
    publicvoid onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    Button button
    = (Button) findViewById(R.id.button1);
    button.setOnClickListener(
    new OnClickListener() {

    @Override
    publicvoid onClick(View v) {

    //初始化一个自定义的Dialog
    Dialog dialog = new MyDialog(MyDialogActivity.this,
    R.style.MyDialog);

    dialog.show();
    }
    });

    }
    }
    复制代码

      主布局文件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>
    复制代码

      新建一个自定义的Dialog类,取名MyDialog,继承自Dialog

    复制代码
    package com.and.mydialog;

    import android.app.Dialog;
    import android.content.Context;
    import android.os.Bundle;
    import android.view.LayoutInflater;
    import android.view.View;

    publicclass MyDialog extends Dialog {

    Context context;
    public MyDialog(Context context) {
    super(context);
    // TODO Auto-generated constructor stub
    this.context = context;
    }
    public MyDialog(Context context, int theme){
    super(context, theme);
    this.context =
    context;
    }
    @Override
    protectedvoid onCreate(Bundle savedInstanceState) {
    // TODO Auto-generated method stub
    super.onCreate(savedInstanceState);
    this.setContentView(R.layout.dialog);
    }

    }
    复制代码

      

    相应的布局文件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
    ="wrap_content"
    android:layout_height
    ="wrap_content"
    android:gravity
    ="center_vertical|center_horizontal"
    android:background
    ="@drawable/dialog_bg">
    <RelativeLayout
    android:layout_width="fill_parent"
    android:layout_height
    ="wrap_content"
    android:paddingLeft
    ="30dip"
    android:paddingTop
    ="10dip">
    <ImageView
    android:id="@+id/dialog_title_image"
    android:layout_alignParentLeft
    ="true"
    android:layout_width
    ="wrap_content"
    android:layout_height
    ="wrap_content"
    android:background
    ="@drawable/dialog_title_image"/>
    <TextView
    android:layout_width="wrap_content"
    android:layout_height
    ="wrap_content"
    android:layout_marginLeft
    ="10dip"
    android:layout_centerInParent
    ="true"
    android:text
    ="Title"
    android:layout_toRightOf
    ="@id/dialog_title_image"
    android:textColor
    ="#000000"
    android:textSize
    ="30sp"/>

    </RelativeLayout>
    <TextView
    android:layout_width="fill_parent"
    android:layout_height
    ="1dip"
    android:background
    ="@drawable/lins"
    android:layout_marginTop
    ="5dip"/>

    <TextView
    android:layout_width="fill_parent"
    android:layout_height
    ="wrap_content"
    android:text
    ="This is a custom dialog"
    android:textColor
    ="#000000"
    android:layout_marginTop
    ="10dip"
    android:layout_marginLeft
    ="30dip"/>
    <RelativeLayout
    android:layout_width="fill_parent"
    android:layout_height
    ="wrap_content"
    android:paddingTop
    ="10dip"
    android:gravity
    ="bottom|center_horizontal"
    android:paddingBottom
    ="10dip">
    <Button
    android:id="@+id/dialog_button_cancel"
    android:layout_alignParentLeft
    ="true"
    android:layout_width
    ="100dip"
    android:layout_height
    ="wrap_content"
    android:text
    ="确定"/>
    <Button
    android:id="@+id/dialog_button_ok"
    android:layout_width
    ="100dip"
    android:layout_height
    ="wrap_content"
    android:layout_toRightOf
    ="@id/dialog_button_cancel"
    android:layout_marginLeft
    ="35dip"
    android:text
    ="取消"/>
    </RelativeLayout>
    </LinearLayout>
    复制代码

      最主要的,是自定义的Style,我们自定义一个式样,用来改变默认的Dialog样式

    在values文件夹下新建一个styles.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/dialog_bg</item>
    <item name="android:windowIsFloating">true</item>
    <item name="android:windowContentOverlay">@null</item>

    </style>
    </resources>
    复制代码

      这样应该就OK了,为了方便大家测试本示例,在此一并附上不怎么好看的素材。。。

     注意,这里有三张图片,第三张图片是一条线,在自定义的式样的时候取消了标题栏,为了美观,添加此线条,看上去还是有标题栏的感觉。。。在此基本上完成了。

    由于水平有限,这些内容基本上都是在网上找的,然后自己整理了一下,写了一篇相对比较清晰的,如果大家还有什么疑问的话,随时可以跟我联系,共同学习。。。

    ———————————————————————————忧伤的分割线——————————————————————————

    不好意思,刚刚实测了一下,发现还有一个很简单的方法,在不改变前面的布局前提下,只需要修改主类(MyDialogActivity.java)

    复制代码
    package com.and.mydialog;
    

    import android.app.Activity;
    import android.app.AlertDialog;
    import android.app.Dialog;
    import android.content.DialogInterface;
    import android.os.Bundle;
    import android.view.KeyEvent;
    import android.view.LayoutInflater;
    import android.view.Menu;
    import android.view.MenuItem;
    import android.view.View;
    import android.view.View.OnClickListener;
    import android.widget.Button;
    import android.widget.Toast;

    publicclass MyDialogActivity extends Activity {
    /** Called when the activity is first created. */
    @Override
    publicvoid onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    Button button
    = (Button) findViewById(R.id.button1);
    button.setOnClickListener(
    new OnClickListener() {

    @Override
    publicvoid onClick(View v) {

    // Dialog dialog = new MyDialog(MyDialogActivity.this,
    // R.style.MyDialog);
                    //此处直接new一个Dialog对象出来,在实例化的时候传入主题
                    Dialog dialog = new Dialog(MyDialogActivity.this, R.style.MyDialog);
    //设置它的ContentView
                    dialog.setContentView(R.layout.dialog);
    

    dialog.show();
    }
    });

    }
    }
    复制代码

    先来一张图吧,很简单,只有一个Activity,当点击Button的时候就弹出这个自定义的Dialog

    里面的几张图都比较丑,我不多会美工,随便用powerpoint画了几张图,原理是一样的,先不计较这些。下面正入正题

    为了照顾到所有的码农,在些把所有的代码都贴出来

    新建工程在此就不贴出来了,只是为了方便大家的复制粘贴,取包名为com.and.mydialog,主Activity取名为MyDialogActivity

    复制代码
    package com.and.mydialog;

    import android.app.Activity;
    import android.app.AlertDialog;
    import android.app.Dialog;
    import android.content.DialogInterface;
    import android.os.Bundle;
    import android.view.KeyEvent;
    import android.view.LayoutInflater;
    import android.view.Menu;
    import android.view.MenuItem;
    import android.view.View;
    import android.view.View.OnClickListener;
    import android.widget.Button;
    import android.widget.Toast;

    publicclass MyDialogActivity extends Activity {
    /** Called when the activity is first created. */
    @Override
    publicvoid onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    Button button
    = (Button) findViewById(R.id.button1);
    button.setOnClickListener(
    new OnClickListener() {

    @Override
    publicvoid onClick(View v) {

    //初始化一个自定义的Dialog
    Dialog dialog = new MyDialog(MyDialogActivity.this,
    R.style.MyDialog);

    dialog.show();
    }
    });

    }
    }
    复制代码

      主布局文件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>
    复制代码

      新建一个自定义的Dialog类,取名MyDialog,继承自Dialog

    复制代码
    package com.and.mydialog;

    import android.app.Dialog;
    import android.content.Context;
    import android.os.Bundle;
    import android.view.LayoutInflater;
    import android.view.View;

    publicclass MyDialog extends Dialog {

    Context context;
    public MyDialog(Context context) {
    super(context);
    // TODO Auto-generated constructor stub
    this.context = context;
    }
    public MyDialog(Context context, int theme){
    super(context, theme);
    this.context =
    context;
    }
    @Override
    protectedvoid onCreate(Bundle savedInstanceState) {
    // TODO Auto-generated method stub
    super.onCreate(savedInstanceState);
    this.setContentView(R.layout.dialog);
    }

    }
    复制代码

      

    相应的布局文件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
    ="wrap_content"
    android:layout_height
    ="wrap_content"
    android:gravity
    ="center_vertical|center_horizontal"
    android:background
    ="@drawable/dialog_bg">
    <RelativeLayout
    android:layout_width="fill_parent"
    android:layout_height
    ="wrap_content"
    android:paddingLeft
    ="30dip"
    android:paddingTop
    ="10dip">
    <ImageView
    android:id="@+id/dialog_title_image"
    android:layout_alignParentLeft
    ="true"
    android:layout_width
    ="wrap_content"
    android:layout_height
    ="wrap_content"
    android:background
    ="@drawable/dialog_title_image"/>
    <TextView
    android:layout_width="wrap_content"
    android:layout_height
    ="wrap_content"
    android:layout_marginLeft
    ="10dip"
    android:layout_centerInParent
    ="true"
    android:text
    ="Title"
    android:layout_toRightOf
    ="@id/dialog_title_image"
    android:textColor
    ="#000000"
    android:textSize
    ="30sp"/>

    </RelativeLayout>
    <TextView
    android:layout_width="fill_parent"
    android:layout_height
    ="1dip"
    android:background
    ="@drawable/lins"
    android:layout_marginTop
    ="5dip"/>

    <TextView
    android:layout_width="fill_parent"
    android:layout_height
    ="wrap_content"
    android:text
    ="This is a custom dialog"
    android:textColor
    ="#000000"
    android:layout_marginTop
    ="10dip"
    android:layout_marginLeft
    ="30dip"/>
    <RelativeLayout
    android:layout_width="fill_parent"
    android:layout_height
    ="wrap_content"
    android:paddingTop
    ="10dip"
    android:gravity
    ="bottom|center_horizontal"
    android:paddingBottom
    ="10dip">
    <Button
    android:id="@+id/dialog_button_cancel"
    android:layout_alignParentLeft
    ="true"
    android:layout_width
    ="100dip"
    android:layout_height
    ="wrap_content"
    android:text
    ="确定"/>
    <Button
    android:id="@+id/dialog_button_ok"
    android:layout_width
    ="100dip"
    android:layout_height
    ="wrap_content"
    android:layout_toRightOf
    ="@id/dialog_button_cancel"
    android:layout_marginLeft
    ="35dip"
    android:text
    ="取消"/>
    </RelativeLayout>
    </LinearLayout>
    复制代码

      最主要的,是自定义的Style,我们自定义一个式样,用来改变默认的Dialog样式

    在values文件夹下新建一个styles.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/dialog_bg</item>
    <item name="android:windowIsFloating">true</item>
    <item name="android:windowContentOverlay">@null</item>

    </style>
    </resources>
    复制代码

      这样应该就OK了,为了方便大家测试本示例,在此一并附上不怎么好看的素材。。。

     注意,这里有三张图片,第三张图片是一条线,在自定义的式样的时候取消了标题栏,为了美观,添加此线条,看上去还是有标题栏的感觉。。。在此基本上完成了。

    由于水平有限,这些内容基本上都是在网上找的,然后自己整理了一下,写了一篇相对比较清晰的,如果大家还有什么疑问的话,随时可以跟我联系,共同学习。。。

    ———————————————————————————忧伤的分割线——————————————————————————

    不好意思,刚刚实测了一下,发现还有一个很简单的方法,在不改变前面的布局前提下,只需要修改主类(MyDialogActivity.java)

    复制代码
    package com.and.mydialog;

    import android.app.Activity;
    import android.app.AlertDialog;
    import android.app.Dialog;
    import android.content.DialogInterface;
    import android.os.Bundle;
    import android.view.KeyEvent;
    import android.view.LayoutInflater;
    import android.view.Menu;
    import android.view.MenuItem;
    import android.view.View;
    import android.view.View.OnClickListener;
    import android.widget.Button;
    import android.widget.Toast;

    publicclass MyDialogActivity extends Activity {
    /** Called when the activity is first created. */
    @Override
    publicvoid onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    Button button
    = (Button) findViewById(R.id.button1);
    button.setOnClickListener(
    new OnClickListener() {

    @Override
    publicvoid onClick(View v) {

    // Dialog dialog = new MyDialog(MyDialogActivity.this,
    // R.style.MyDialog);
                    //此处直接new一个Dialog对象出来,在实例化的时候传入主题
                    Dialog dialog = new Dialog(MyDialogActivity.this, R.style.MyDialog);
    //设置它的ContentView
                    dialog.setContentView(R.layout.dialog);

    dialog.show();
    }
    });

    }
    }
    复制代码
  • 相关阅读:
    命运(经典dp)
    A * B Problem Plus(fft)
    Hat's Fibonacci(大数加法+直接暴力)
    Can you find it?(哈希)
    String 类型与char 类型 输入
    QT 之 QMutexLocker如何安全锁住全局变量
    C语言中access/_access函数的使用实例详解
    %02x与%2x 之间的区别
    函数名&函数名取地址
    函数指针及其定义和用法,C语言函数指针详解
  • 原文地址:https://www.cnblogs.com/qingblog/p/2671473.html
Copyright © 2011-2022 走看看