ConciseDialog 链式调用,动态,快速改变Dialog内容/数据/样式

android开发的朋友们,大家一家会遇到这样的需求,需要在XX页面,弹出层,然后在弹出层中进行各种操作。
曾经的方法,一个弹出层,对应一个功能。
现在想想,写的想死。
于是乎,ConciseDialog便被设计出来了。
使用方法如下:

first

allprojects {
    repositories {
        ...
        maven { url 'https://jitpack.io' }
    }
}
dependencies {
        compile 'com.github.deilsky:ConciseDialog:v1.1'
}

second

    ConciseDialog.newInstance(R.layout.nav_dialog, new ConciseDialog.ReadyListener() {
                    @Override
                    public void onComplete(View view) {
                        initDialogView(view);
                    }

                    @Override
                    public void onError(String e) {

                    }
                }).matchWidth(true)
                  .gravity(ConciseDialog.DialogGravity.MIDDLE)
                  .absolute(true)
                  .height(80)//高度 百分比
                  .show(MainActivity.this.getFragmentManager(), "test1");
    private void initDialogView(final View v) {
      title = v.findViewById(R.id.tv_d_title);
      title.setText("测试标题");
      yes = v.findViewById(R.id.nav_yes);
      yes.setText("是");
      yes.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Toast.makeText(MainActivity.this, "是", Toast.LENGTH_SHORT).show();
            }
        });
        no = v.findViewById(R.id.nav_no);
        no.setText("否");
        no.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Toast.makeText(MainActivity.this, "否", Toast.LENGTH_SHORT).show();
            }
        });
    }

third 讲解

      1.ConciseDialog 继承于android.app.DialogFragment; 所以可以像正常的Dialog一样使用
      2.ConciseDialog.newInstance(R.layout.nav_dialog, new ConciseDialog.ReadyListener() {
            @Override
            public void onComplete(View view) {
              initDialogView(view);//dialog成功弹出,加载layout成功时,回调
            }
            @Override
            public void onError(String e) {}
        }) //根据使用需要,可以引入各种layout文件
      3.gravity //显示的位置:上,中,下
      4.absolute //是否使用绝对宽高
      5.matchWidth// 宽度是否满屏
      6.height //绝对模式下,高度为xxxdp;非绝对模式下,高度为屏幕的xx%
      7.width //仅在matchWidth为false时,生效;绝对模式下,宽度为xxxdp;非绝对模式下,宽度为屏幕的xx%
      8.动态切换layout/数据时,需要为讲解2中的代码,进行实例。通过onComplete(View view)进行重置数据

传送门

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

【归心】

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值