一个功能强大的对话框库—让你的项目不再单调

一个快速创建对话框的工具类库

效果图如下:

特点
  • 支持各种样式的配置
  • 集成了sweet-alert-dialog
  • 集成了Titanic的进度框动画样式
  • 集成了AVLoadingIndicatorView的动画样式
如何使用
  • 引入依赖库

    allprojects {
    	repositories {
    		...
    		maven { url 'https://jitpack.io' }
    	}
    }
    复制代码
  • 添加compile

dependencies {
        compile 'com.github.yilylong:CBDialog:v1.0.2'
}    
复制代码
  • 基本使用方法
new CBDialogBuilder(this)
.setTouchOutSideCancelable(true)
.showCancelButton(true)
.setTitle("这是一个普通样式的对话框")
.setMessage("this is a normal CBDialog")
.setConfirmButtonText("确定")
.setCancelButtonText("取消")
.setDialogAnimation(CBDialogBuilder.DIALOG_ANIM_SLID_BOTTOM)
.create().show(); 
复制代码
  • 可以传入不同的样式

    CBDialogBuilder.DIALOG_STYLE_NORMAL
    CBDialogBuilder.DIALOG_STYLE_PROGRESS
    CBDialogBuilder.DIALOG_STYLE_PROGRESS_TITANIC
    CBDialogBuilder.DIALOG_STYLE_PROGRESS_AVLOADING
    
    new CBDialogBuilder(this, CBDialogBuilder.DIALOG_STYLE_PROGRESS_TITANIC).create();
    .setTouchOutSideCancelable(true) 设置是否点击对话框以外的区域dismiss对话框  
    .showCancelButton(true) 是否显示取消按钮
    .setDialogAnimation(CBDialogBuilder.DIALOG_ANIM_SLID_BOTTOM) 设置对话框的动画样式 
    .setDialoglocation(CBDialogBuilder.DIALOG_LOCATION_BOTTOM)  设置对话框位于屏幕的位置
    .setButtonClickListener(true, new CBDialogBuilder.onDialogbtnClickListener() { 添加按钮回调监听
                            @Override
                            public void onDialogbtnClick(Context context, Dialog dialog, int whichBtn) {
                                switch (whichBtn) {
                                    case BUTTON_CONFIRM:
                                        Toast.makeText(context, "点击了确认按钮", Toast.LENGTH_SHORT).show();
                                        break;
                                    case BUTTON_CANCEL:
                                        Toast.makeText(context, "点击了取消按钮", Toast.LENGTH_SHORT).show();
                                        break;
                                    default:
                                        break;
                                }
                            }
                        })
                        
    复制代码
  • 设置一个列表 和 列表项选中回调监听

    .setItems(new String[]{"较小", "中等", "较大", "巨无霸"}, new CBDialogBuilder.onDialogItemClickListener() {
           @Override
           public void onDialogItemClick(CBDialogBuilder.DialogItemAdapter ItemAdapter,Context context, CBDialogBuilder dialogbuilder,             Dialog dialog,int position) {
            //TODO 保存选中设置
            dialog.dismiss();
            }
         }, 2)
    复制代码
  • 设置一个进度框的超时监听

     .setOnProgressOutTimeListener(5, new CBDialogBuilder.onProgressOutTimeListener() {
                            @Override
                            public void onProgressOutTime(Dialog dialog, TextView dialogMsgTextView) {
                            // do your work
                            }
      })
    复制代码

  • 设置avloading进度框动画样式颜色

    .setProgressIndicatorColor(0xaa198675)
    .setProgressIndicator(CBDialogBuilder.INDICATOR_BallRotate)
    复制代码
  • 设置自定义的dialog布局文件

    在构建的时候传入R.layout.layout_custom_dialog_layout自定义布局文件即可,但是里面的个控件(标题,消息,按钮)的ID要跟cb_dialog.xml 里面一致

    new CBDialogBuilder(this, R.layout.layout_custom_dialog_layout, 1.0f)
                        ...
                        .create().show();   
    复制代码
  • 设置自定义消息布局文件

    .setView(R.layout.custom_msg_view)
    复制代码

更多配置方法参考DEMO

项目地址

https://github.com/yilylong/CBDialog

相信自己,没有做不到的,只有想不到的

如果你觉得此文对您有所帮助, 微信公众号:终端研发部

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值