酷炫的android dialog弹出框

基于github开源框架基础上运用在自己的项目中,

效果如下:


本演示项目 基于Android Studio开发,在对应moudle下的gradle.build中添加一下依赖

dependencies {
    compile 'com.nineoldandroids:library:2.4.0'
    compile 'com.github.sd6352051.niftydialogeffects:niftydialogeffects:1.0.0@aar'
}


核心代码列出:

String []type = {"Fadein", "Slideleft", "Slidetop", "SlideBottom", "Slideright", "Fall", "Newspager", "Fliph", "Flipv", "RotateBottom", "RotateLeft", "Slit", "Shake", "Sidefill"};
            int i= (int) (type.length*Math.random());
            Effectstype effect = null;
            switch (i){
                case 0:effect=Effectstype.Fadein;break;
                case 1:effect=Effectstype.Slideright;break;
                case 2:effect=Effectstype.Slideleft;break;
                case 3:effect=Effectstype.Slidetop;break;
                case 4:effect=Effectstype.SlideBottom;break;
                case 5:effect=Effectstype.Newspager;break;
                case 6:effect=Effectstype.Fall;break;
                case 7:effect=Effectstype.Sidefill;break;
                case 8:effect=Effectstype.Fliph;break;
                case 9:effect=Effectstype.Flipv;break;
                case 10:effect=Effectstype.RotateBottom;break;
                case 11:effect=Effectstype.RotateLeft;break;
                case 12:effect=Effectstype.Slit;break;
                case 13:effect=Effectstype.Shake;break;
            }
            final NiftyDialogBuilder dialogBuilder = NiftyDialogBuilder.getInstance(this);

            dialogBuilder
                    // 重点设置
                    .withEffect(effect)        //设置对话框弹出样式
                    //.setCustomView(R.layout.custom, MainActivity.this) // 设置自定义对话框的布局
                    .withDuration(700)              //动画显现的时间(时间长就类似放慢动作)

                    // 基本设置
                    .withTitle("Info")         //设置对话框标题
                    .withTitleColor("#FFFFFF")          //设置标题字体颜色
                    .withDividerColor("#11000000")      //设置分隔线的颜色
                    .withMessage("Are you sure logout?")//设置对话框显示内容
                    .withMessageColor("#FFFFFFFF")       //设置消息字体的颜色
                    .withDialogColor("#FFE74C3C")        //设置对话框背景的颜色
                    //.withIcon(getResources().getDrawable(R.drawable.logo)) //设置标题的图标
                    // 设置是否模态,默认false,表示模态,
                    //要求必须采取行动才能继续进行剩下的操作 | isCancelable(true)
                    .isCancelableOnTouchOutside(true)
                    .withButton1Text("Yes")               //设置按钮1的文本
                    .withButton2Text("No")          //设置按钮2的文本

                    .setButton1Click(new View.OnClickListener() {
                        @Override
                        public void onClick(View v) {
                            Toast.makeText(v.getContext(), "I am btnYes", Toast.LENGTH_SHORT).show();
                            dialogBuilder.dismiss();
                        }
                    })
                    .setButton2Click(new View.OnClickListener() {
                        @Override
                        public void onClick(View v) {
                            Toast.makeText(v.getContext(), "I am btnNo", Toast.LENGTH_SHORT).show();
                            dialogBuilder.dismiss();
                        }
                    })
                    .show();
   

 app demo下载地址: http://fir.im/NiftyDialog


第一次写博客, 写的不好,请多包涵,欢迎留言指教!大笑

  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值