美文网首页
自定义Dialog

自定义Dialog

作者: 简书ZJM | 来源:发表于2017-02-27 13:12 被阅读0次

说明

此文模仿
http://www.jianshu.com/p/68dc2d15537e,结合了自身需求更改了部分内容

自定义Dialog三部曲

  1. 编写自定义布局
  2. 自定义一个类并继承AlertDialog
  3. 实现调用环节

自定义布局

image
  • 系统自带的dialog是无法实现该效果的,所以需要使用自定义Dialog
  • 这里只需要按正常的布局实现即可
    <LinearLayout>
        <TextView
            android:text="Demo"
            />
    </LinearLayout>
    <TextView
        android:text="xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx"
        />
        <Button
            android:id="@+id/Dialog_Button_item1"
            android:text="item1"
            />
        <Button
            android:id="@+id/Dialog_Button_item2"
            android:text="item2"
            />
        <Button
            android:id="@+id/Dialog_Button_item3"
            android:text="item3"/>
  • 这里的代码主要为了展示我们只需要很正常的布局即可,删掉了大部分没有意义的代码

自定义一个类并继承AlertDialog

public class MyAlertDialog extends AlertDialog implements View.OnClickListener{
    private Context mContext;
    private Button item1Btn;
    private Button item2Btn;
    private Button item3Btn;
    public MyAlertDialog(Context context){//构造类,这里注意一定要public
        super(context);
        mContext= context;
    }
    @Override
    protected void onCreate(Bundle savedInstancesState){
        super.onCreate(savedInstancesState);
        setContentView(R.layout.view_dialog);
        initView();
        initDate();
    }
    private void initView(){//初始化视图
        GoodBtn= (Button) findViewById(R.id.Dialog_Button_good);
        NormalBtn= (Button) findViewById(R.id.Dialog_Button_normal);
        BadBtn= (Button) findViewById(R.id.Dialog_Button_bad);
    }
    private void initDate(){//注册监听器
        GoodBtn.setOnClickListener(this);
        NormalBtn.setOnClickListener(this);
        BadBtn.setOnClickListener(this);
    }
    @Override
    public void onClick(View v){
        switch (v.getId()){
            case R.id.Dialog_Button_good:
                break;
            case R.id.Dialog_Button_normal:
                break;
            case R.id.Dialog_Button_bad:
                break;
            default:
                break;
        }
    }
}

实现调用环节

  • 在调用的地方实例化,并调用show()展示
MyAlertDialog myAlertDialog=new MyAlertDialog(MainActivtiy.this);
myAlertDialog.show();
  • 实际
public class MainActivity extends AutoLayoutActivity {
    private Button test;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        test= (Button) findViewById(R.id.Button_test);
        test.setOnClickListener(new View.OnClickListener(){
            @Override
            public void onClick(View v){
                MyAlertDialog myAlertDialog=new MyAlertDialog(MainActivity.this);
                myAlertDialog.show();
            }
        });
    }

}

相关文章

  • Dialog

    安卓dialog的使用+如何自定义dialog自定义Dialog自定义Dialog 自定义

  • 自定义Dialog

    自定义Dialog的主题 自定义Dialog的布局文件 继承Dialog 并在onCreate方法中将布局设置给D...

  • 实现图片Dialog中带ViewPager

    效果图 实现思路 自定义Dialog,为Dialog添加自定义布局,自定义PagerAdapter以及PageTr...

  • 【Android】自定义全屏dialog

    一、在themes.xml中添加自定义dialog的样式 二、创建dialog基类 三、创建自定义dialog的布...

  • Android圆角对话框Dialog

    需求:模仿iOS样式Dialog对话框。 自定义Dialog 核心代码: Dialog样式: Dialog布局文件...

  • Android自定义Dialog及其点击事件

    在项目开发中,经常要用到dialog。但是系统的dialog太丑,所有我们要自定义dialog。下面的先介绍自定义...

  • 一个漂亮的自定义Dialog

    这是一个自定义的dialog项目 自定义的dialog,具有如下特点 圆角的dialog View 圆形图片的ti...

  • Flutter Dialog 动画

    本文对 Dialog 做一次系统性学习记录,包括系统 Dialog,自定义 Dialog,Dialog 动画。 A...

  • 自定义Dialog

    仿IOS自定义的Dialog: 1、Util帮助类创建dialog 2、布局文件 :loading_dialog....

  • 自定义Dialog实现透明无遮罩进度框

    效果图: 自定义Dialog继承自Dialog params.dimAmount=0:设置dialog弹出后,背景...

网友评论

      本文标题:自定义Dialog

      本文链接:https://www.haomeiwen.com/subject/lodzwttx.html