Android开篇之高仿ios风格的自定义Dialog
2016-12-21 09:03
417 查看
一 概述
经常做项目的时候,你会发现。AlertDialog这个控件,我们也经常用到,比如说当你提交一些数据的时候啊,确定是否退出程序的时候啊等等场景,于是我们很自然的想到用到这个控件。当我们开发完成的时候,给测试测的时候。测试来一句“这什么鬼东西,这么丑。能不能做成和ios一样的效果”,宝宝心里苦啊,怪我咯.哎没办法,谁让google自带的效果都是很丑呢(现在最新系统自带的dialog,看起来很好看。我相信总有一天,android总有超越ios的一天)。于是就自定义一个呗。
对于自定义控件这块。小编准备后面分一个模块专门讲解。因为这块要牵扯到很多内容,是安卓开发的一个重点和一个难点。今天就单独拿这个控件权当热热身哈下面先奉上效果图基本上和ios的效果很相似了。好那么接下来我们就开始自定义吧。先上代码
public class CustomDialog extends Dialog { public CustomDialog(Context mcontext){ super(mcontext); } public CustomDialog(Context mcontext,int Theme){ super(mcontext,Theme); } public static class Builder{ public Context mcontext;//上下文 public String title;//标题 public String message;//信息 public View mconvertView;//加载的布局 private String confirm_btnText; // 按钮名称“确定” private String cancel_btnText; // 按钮名称“取消” private String neutral_btnText; // 按钮名称“隐藏” /* 按钮监听事件 */ private OnClickListener confirm_btnClickListener; private OnClickListener cancel_btnClickListener; private OnClickListener neutral_btnClickListener; public Builder(Context mcontext){ this.mcontext=mcontext; } //设置标题 public Builder setTitle(String title) { this.title = title; return this; } //设置信息 public Builder setMessage(String message) { this.message = message; return this; } //设置布局 public Builder setMconvertView(View mconvertView) { this.mconvertView = mconvertView; return this; } public Builder setPositiveButton(String confirm_btnText, OnClickListener listener) { this.confirm_btnText = confirm_btnText; this.confirm_btnClickListener = listener; return this; } public Builder setPositiveButton(int confirm_btnText, OnClickListener listener) { this.confirm_btnText = (String)mcontext.getText(confirm_btnText); this.confirm_btnClickListener = listener; return this; } public Builder setNegativeButton(String cancel_btnText, OnClickListener listener){ this.cancel_btnText=cancel_btnText; this.cancel_btnClickListener=listener; return this; } public Builder setNegativeButton(int cancel_btnText, OnClickListener listener){ this.cancel_btnText=(String)mcontext.getText(cancel_btnText); this.cancel_btnClickListener=listener; return this; } public Builder setNeutralButton(String neutral_btnText, OnClickListener listener) { this.neutral_btnText = neutral_btnText; this.neutral_btnClickListener = listener; return this; } public Builder setNeutralButton(int neutral_btnText, OnClickListener listener) { this.neutral_btnText = (String)mcontext.getText(neutral_btnText); this.neutral_btnClickListener = listener; return this; } public CustomDialog creat(){ LayoutInflater inflater = (LayoutInflater) mcontext .getSystemService(Context.LAYOUT_INFLATER_SERVICE); final CustomDialog dialog=new CustomDialog(mcontext,R.style.mystyle); View view=inflater.inflate(R.layout.customdialog,null); View line=view.findViewById(R.id.single_line); View line2=view.findViewById(R.id.second_line); Button confirm=(Button)view.findViewById(R.id.confirm_btn); Button neutral=(Button)view.findViewById(R.id.neutral_btn); Button cancel=(Button)view.findViewById(R.id.cancel_btn); // dialog.addContentView(view,new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT)); if(confirm_btnText!=null&&cancel_btnText!=null&&neutral_btnText!=null){ confirm.setText(confirm_btnText); if(neutral_btnClickListener!=null){ neutral.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { neutral_btnClickListener.onClick(dialog, DialogInterface.BUTTON_NEUTRAL); } }); }else{ neutral.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { dialog.dismiss(); } }); } }else{ neutral.setVisibility(View.GONE); line.setVisibility(View.GONE); } if(confirm_btnText!=null){ confirm.setVisibility(View.VISIBLE); confirm.setText(confirm_btnText); if(confirm_btnClickListener!=null){ confirm.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { confirm_btnClickListener.onClick(dialog,DialogInterface.BUTTON_POSITIVE); } }); }else{ confirm.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { dialog.dismiss(); } }); } }else{ confirm.setVisibility(View.GONE); line2.setVisibility(View.GONE); cancel.setBackgroundResource( R.drawable.single_btn_select); } if(cancel_btnText!=null){ cancel.setVisibility(View.VISIBLE); cancel.setText(cancel_btnText); if(cancel_btnClickListener!=null){ cancel.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { cancel_btnClickListener.onClick(dialog,DialogInterface.BUTTON_NEGATIVE); } }); }else{ cancel.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { dialog.dismiss(); } }); } }else{ cancel.setVisibility(View.GONE); line2.setVisibility(View.GONE); confirm.setBackgroundResource( R.drawable.single_btn_select); } if(neutral_btnText!=null){ neutral.setVisibility(View.VISIBLE); neutral.setText(neutral_btnText); if(neutral_btnClickListener!=null) { neutral.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { neutral_btnClickListener.onClick(dialog,DialogInterface.BUTTON_NEUTRAL); } }); }else{ neutral.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { dialog.dismiss(); } }); } }else{ neutral.setBackgroundResource(R.drawable.single_btn_select); } if(message!=null){ TextView vMessage=(TextView)view.findViewById(R.id.message); vMessage.setText(message); }else if (mconvertView != null) { ((LinearLayout) view.findViewById(R.id.layout)) .removeAllViews(); ((LinearLayout) view.findViewById(R.id.layout)).addView( mconvertView, new ViewGroup.LayoutParams( ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT)); } dialog.setContentView(view) 956a ; return dialog; } } }好了 代码 就是这些 基本上都能够看懂,使用的时候就直接和系统的dialog一样调用就ok了。
资源地址如下自定义Dialog
相关文章推荐
- Android自定义iOS风格Dialog
- Android模拟IOS风格的自定义Dialog底部弹窗案例
- Android 自定义View学习(3)--仿IOS风格滑动按钮
- Android-通过自定义ViewPager来高仿土巴兔选择装修风格效果(中间放大效果)
- Android 自定义符合软件整体风格的dialog
- Android仿IOS自定义AlertDialog提示框
- Android AlertDialog对话框自定义风格的另类实现
- Android UI设计系列之自定义Dialog实现各种风格的对话框效果(7)
- Android material 风格和 ios 风格的 dialog,可传入 context 构建,在任意地方弹出,一行代码调用
- 【Android之IOS风格Dialog对话框】
- Android AlertDialog对话框自定义风格的另类实现
- Android自定义View-------IOS风格的滑动开关
- (转)android底部弹出iOS7风格对话选项框(QQ对话框)--第三方开源--IOS_Dialog_Library
- Android 高仿IOS底部Dialog对话框。
- Android UI设计之<七>自定义Dialog,实现各种风格效果的对话框
- Android自定义View-------IOS风格的滑动开关
- IOS-通过自定义iCarousel来高仿土巴兔选择装修风格效果(中间选中项放大)
- (转)android底部弹出iOS7风格对话选项框(QQ对话框)--第三方开源--IOS_Dialog_Library
- AndroidIOS风格底部选择器(支持时间,日期,自定义)
- Android自定义Dialog仿IOS的Dialog