Android开篇之高仿ios风格的自定义Dialog
来源:互联网 发布:sai绘画软件怎么下载 编辑:程序博客网 时间:2024/04/28 08:35
一 概述
经常做项目的时候,你会发现。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); return dialog; } }}好了 代码 就是这些 基本上都能够看懂,使用的时候就直接和系统的dialog一样调用就ok了。
资源地址如下自定义Dialog
0 0
- Android开篇之高仿ios风格的自定义Dialog
- Android自定义Dialog仿IOS的Dialog
- Dialog 之高仿IOS
- Android自定义iOS风格Dialog
- 仿ios风格dialog
- 仿ios9风格的Android 分享dialog
- Android 高仿IOS底部Dialog对话框。
- 【Android自定义控件】仿IOS风格的搜索框
- 【Android自定义控件】仿IOS风格的搜索框
- 【Android之IOS风格Dialog对话框】
- Android自定义View之popupwindow进阶封装:高仿ios “item动画弹出”效果的popupwindow。
- 【Android】自定义风格的各种dialog
- Android:自定义Material Design风格的Dialog
- Android:自定义Material Design风格的Dialog
- Android仿iOS样式的dialog
- 仿IOS的dialog
- Android模拟IOS风格的自定义Dialog底部弹窗案例
- Android 自定义View学习(3)--仿IOS风格滑动按钮
- 经典算法之冒泡排序
- BDBR和BD-PSNR
- C语言到C++的升级
- 每天一个linux命令(25):linux文件属性详解
- nginx配置HTTPS
- Android开篇之高仿ios风格的自定义Dialog
- 微信小程序开发之新手填坑
- 聚类算法
- tomcat 使用 网络文件服务NFS
- ionic 本地存在pouchDB+sqlite 浏览器运行正常,手机运行异常的处理方法
- 利用投影算法来计算系统矩阵左乘和右乘
- 曹德旺所感之中国经济现状
- nodeJs学习过程之一个图片上传显示的例子
- IPTV/OTT 也许只是过渡阶段的产物,IPTV+OTT、DVB+OTT的几点思考