wwmz / Wmzdialog
Licence: mit
功能最多样式最多的弹窗,支持普通/微信底部/日期/地区/日历/选择/编辑/分享/菜单/自定义弹窗等,支持多种动画,链式编程调用(Pop-up windows with the most functions and styles, support normal/WeChat bottom/date/region/calendar/select/edit/share/menu/custom pop-up windows, etc., support multiple animations, chain programming calls)
Stars: ✭ 673
Projects that are alternatives of or similar to Wmzdialog
Customalertviewdialogue
Custom AlertView Dialogue is the world's most advanced alert view library. Custom AlertView Dialogue includes simple message popups, confirmation alerts, selector popups, action sheet bottom menus, and input/feedback contact forms.
Stars: ✭ 100 (-85.14%)
Mutual labels: dialog, menu, alert, select
Vue Ui For Pc
基于Vue2.x的一套PC端UI组件,包括了Carousel 跑马灯、Cascader 级联、Checkbox 多选框、Collapse 折叠面板、DatePicker 日期选择、Dialog 对话框、Form 表单、Input 输入框、InputNumber 数字输入框、Layer 弹窗层、Loading 加载、Menu 菜单、Page 分页、Progress 进度条、Radio 单选框、SelectDropDown 仿select、Switch 开关、Table 表格、Tabs 标签页、Textarea 文本框、Tooltip 文字提示、BackTop 返回顶部、steps 步骤条、Transfer 穿梭框、Tree 树形、Upload 文件上传、Lazy 图片懒加载、Loading 加载、Pagination 分页等等
Stars: ✭ 156 (-76.82%)
Mutual labels: dialog, menu, select
Persei
Animated top menu for UITableView / UICollectionView / UIScrollView written in Swift
Stars: ✭ 3,395 (+404.46%)
Mutual labels: custom, menu
Easydropdown
A lightweight library for building beautiful styleable <select> elements
Stars: ✭ 337 (-49.93%)
Mutual labels: menu, select
Android Ago
An Android TextView that always displays an auto refreshing relative time span with respect to a reference time
Stars: ✭ 669 (-0.59%)
Mutual labels: time, textview
Rflutter alert
RFlutter Alert is super customizable and easy-to-use alert / popup dialog library for Flutter. You may create reusable alert styles or add buttons as much as you want with ease.
Stars: ✭ 271 (-59.73%)
Mutual labels: dialog, alert
Md Date Time Picker
An implementation of Material Design Picker components in vanilla CSS, JS, and HTML
Stars: ✭ 272 (-59.58%)
Mutual labels: time, dialog
React Native Awesome Alerts
Awesome alerts for React Native, works with iOS and Android.
Stars: ✭ 391 (-41.9%)
Mutual labels: dialog, alert
mobile-message
基于移动端的弹窗组件,默认提供info、success、warning、error、alert、confirm、multiple、vertical、bottomSheet、prompt,可自定义弹窗。它可以包含任何Html内容可以自定义弹窗的样式,也可以加入自定以的弹窗动画。
Stars: ✭ 13 (-98.07%)
Mutual labels: alert, dialog
Ngx Sweetalert2
Declarative, reactive, and template-driven SweetAlert2 integration for Angular
Stars: ✭ 503 (-25.26%)
Mutual labels: dialog, alert
Sppermissions
Ask permissions with ready-use interface. You can check status permission and if it has been requested before. Support SwiftUI.
Stars: ✭ 4,701 (+598.51%)
Mutual labels: location, dialog
Wmzdropdownmenu
🌹一个能几乎实现所有App各种类型筛选菜单的控件,可悬浮,目前已实现闲鱼/美团/Boss直聘/京东/饿了么/淘宝/拼多多/赶集网/美图外卖等等的筛选菜单,可以自由调用代理实现自己想组装的筛选功能和UI,且控件的生命周期自动管理,悬浮自动管理🌹(A control that can implement almost all types of filtering menus of all apps)
Stars: ✭ 503 (-25.26%)
Mutual labels: custom, menu
SlidingUpMenu
🚀 A very customizable library that allows you to present menu items (from menu resource and/or other sources) to users as a bottom sheet.
Stars: ✭ 26 (-96.14%)
Mutual labels: dialog, menu
Razor.SweetAlert2
A Razor class library for interacting with SweetAlert2
Stars: ✭ 98 (-85.44%)
Mutual labels: alert, dialog
Vuejs Dialog
A lightweight, promise based alert, prompt and confirm dialog
Stars: ✭ 327 (-51.41%)
Mutual labels: dialog, alert
BalloonPopup
Forget Android Toast! BalloonPopup displays a round or squared popup and attaches it to a View, like a callout. Uses the Builder pattern for maximum ease. The popup can automatically hide and can persist when the value is updated.
Stars: ✭ 32 (-95.25%)
Mutual labels: alert, dialog
Popupdialog
A simple, customizable popup dialog for iOS written in Swift. Replaces UIAlertController alert style.
Stars: ✭ 3,709 (+451.11%)
Mutual labels: dialog, alert
Sweetalert
A beautiful replacement for JavaScript's "alert"
Stars: ✭ 21,871 (+3149.78%)
Mutual labels: dialog, alert
WBChainMenu
This will show horizontal menu to a UITableViewCell with chain animation
Stars: ✭ 28 (-95.84%)
Mutual labels: custom, menu
CoolSlidingMenu
A powerful menu that you can customize it。
Stars: ✭ 25 (-96.29%)
Mutual labels: custom, menu
WMZDailog - 功能最多样式最多的弹窗,支持普通/微信底部/提示/加载框/日期/地区/日历/选择/编辑/分享/菜单/自定义弹窗等,支持多种动画,链式编程调用,所有属性均可定制(pod 更新至 1.2.5)
特性
- 链式语法 结构优雅
- 支持任意位置视图的弹窗(包括滚动视图)
- 支持单选/多选
- 支持地区1/2/3级联动
- 支持无限级联动
- 支持加载框
- 支持提示框
- 支持横竖屏
- 支持时间选择(年月日时分秒自由组合+最大最小时间限制)
- 支持支持多种动画
- 支持所有字体颜色/字体大小的设置
- 支持支付视图
- 支持ios13Persent弹窗
- 支持日历
- 支持菜单选择
- 支持默认选中
- 支持所有列表cell样式的自定义
- 支持自定义弹窗
调用枚举说明
typedef enum : NSUInteger{
DialogTypeNornal = 1, //默认弹窗
DialogTypeSheet, //底部弹窗
DialogTypeAuto, //默认弹窗自动消失
DialogTypePay, //支付密码框
DialogTypeShare, //带分享的弹窗
DialogTypeWrite, //带编辑框的弹窗
DialogTypeSelect, //带选择的弹窗
DialogTypePickSelect, //拾取器弹窗
DialogTypeTime, //带倒计时的弹窗
DialogTypePop, //下拉列表选择弹窗
DialogTypeDown, //带下载的弹窗
DialogTypeMenusSelect, //下拉无限级菜单弹窗
DialogTypeAdvertisement, //广告弹窗
DialogTypeLocation, //地区选择
DialogTypeDatePicker, //日期选择
DialogTypeTabbarMenu, //闲鱼 微博+号底部弹窗
DialogTypeNaviMenu, //QQ顶部弹窗
DialogTypeLoading, //加载框
DialogTypeCardPresent , //ios13 present效果
DialogTypeCalander, //日历弹窗
DialogTypeMyView, //自定义弹窗
}DialogType;
弹窗类型 | 图片 |
---|---|
默认弹窗 | |
底部弹窗 | |
自动消失hud弹窗 | |
支付密码框 | |
带分享的弹窗 | |
带编辑框的弹窗 | |
带选择的弹窗 | |
拾取器弹窗 | |
带倒计时的弹窗 | |
下拉列表选择弹窗 | |
带下载的弹窗 | |
下拉无限级菜单弹窗 | |
地区弹窗 | |
日期选择弹窗 | |
顶部菜单弹窗 | |
底部菜单弹窗 | |
加载框 | |
ios13 present效果 | |
日历弹窗 | |
自定义弹窗 |
参数说明(详情使用看demo)
DialogTypeNornal/DialogTypeSheet/DialogTypeSelect。。。
可配置通用参数 | 类型 | 作用 (默认值) |
---|---|---|
wData | id | 数据源 |
wShowAnimation | DialogShowAnination | 出现的动画 default AninatonZoomIn |
wHideAnimation | DialogHideAnination | 消失的动画 default none |
wAnimationDurtion | NSTimeInterval | 动画时间 default 0.8 |
wParentVC | UIViewController | 父控制器 default 当前VC |
wType | DialogType | 弹窗类型 default DialogTypeNornal |
wWidth | CGFloat | 弹窗视图的宽度 default 500 |
wHeight | CGFloat | 弹窗视图的高度 default 自适应高度 300 |
wMainOffsetY | CGFloat | Y间距 default 20 |
wMainOffsetX | CGFloat | X间距 default 15 |
wMainBtnHeight | CGFloat | 按钮高度 default 60 |
wMyCell | UITableViewCell | 自定义cell |
wMainToBottom | BOOL | 视图在最底部 default NO |
wLineColor | UIColor | 线条的颜色 default 333333 |
wLineAlpha | CGFLoat | 线条的透明度 default 0.5 |
wTitle | NSString | 标题文本 default 标题 |
wMessage | NSString | 内容文本 default 内容 |
wOKTitle | NSString | 确定按钮的文本 default 确定 |
wCancelTitle | NSString | 取消按钮的文本 default 取消 |
wOKColor | UIColor | 确定按钮的颜色 default 0xFF9900 |
wCancelColor | UIColor | 取消按钮的颜色 default 0x666666 |
wMainBackColor | UIColor | 弹出视图的背景颜色 default 0xffffff |
wTitleColor | UIColor | 标题文本的颜色 default 0x333333 |
wMessageColor | UIColor | 内容文本的颜色 default 0x333333 |
wOKFont | CGFLoat | 确定按钮的字体大小 default 16.0f |
wCancelFont | CGFLoat | 取消按钮的字体大小 default 16.0f |
wTitleFont | CGFLoat | 标题文本的字体大小 default 14.0f |
wMessageFont | CGFLoat | 内容文本的字体大小 default 16.0f |
wMainRadius | CGFLoat | 弹出视图的圆角 default 15.0f |
wShadowColor | UIColor | 遮罩层的颜色 default 0x333333 |
wShadowAlpha | CGFLoat | 遮罩层的透明度 default 0.4f |
wShadowCanTap | BOOL | 遮罩层能否点击关闭 default YES |
wShadowShow | BOOL | 遮罩层是否显示 default YES |
wEffectShow | BOOL | 毛玻璃是否显示 default NO |
wMultipleSelection | BOOL | 多选 default NO |
wSelectShowChecked | BOOL | 选中是否打钩 default NO |
wTextAlignment | NSTextAlignment | 文本对齐方式 default center |
DialogTypeAuto
DialogTypeAuto参数 | 类型 | 作用 (默认值) |
---|---|---|
wDisappelSecond | CGFLoat | 自动消失的时间 default 1.5f |
DialogTypePay
DialogTypePay参数 | 类型 | 作用 (默认值) |
---|---|---|
wSonData | id | 支付方式选择数据源 |
wKeyBoardMarginY | CGFLoat | 弹窗与键盘的距离 default 70 |
wPayNum | NSInteger | 支付密码位数 default 6(若要设置位数比6大的则要保证宽度足够) |
wDefaultSelectPayStr | NSString | 支付方式默认文本 default 农业银行 |
DialogTypeWrite
DialogTypeWrite参数 | 类型 | 作用 (默认值) |
---|---|---|
wPlaceholder | NSString | 提示语 default 请输入 |
wWirteTextMaxLine | NSInteger | 编辑框可换行的最大行数 default 7 |
wWirteTextMaxNum | NSInteger | 编辑框可输入的最大数字 default -1(-1为不限制) |
wWirteKeyBoardType | UIKeyBoardType | 编辑框的键盘type default UIKeyboardTypeDefault |
DialogTypePop
DialogTypePop参数 | 类型 | 作用 (默认值) |
---|---|---|
wPercentAngle | CGFLoat | 弹出的气泡位置 default 0.5f |
wPercentOrginX | CGFLoat | 弹出视图的中心X轴偏移 default 1.0f (中间) |
wDirection | DiaDirection | 弹出视图的方向 default directionDowm |
wNavigationItem | BOOL | 导航栏位置 default NO |
wTapView | UIView | 触发点的视图 default - 必传 |
wTapRect | CGRect | 如果弹出视图的frame不准确 可以自行调节 |
wTapViewType | DiaPopInView | 所在父视图的类型 default normal |
wTapViewTableViewFoot | BOOL | 父视图的tableviewHead还是tableviewFoot default Head |
wTableViewSectionHead | NSInteger | 在tableViewHead上的按钮所在的headViewSection的index default 0 |
wPopViewBorderWidth | CGFloat | 弹窗视图的borderWidth default 0 |
wPopViewBorderColor | UIColor | 弹窗视图的borderColor default 主题颜色 |
wPopViewRectCorner | DialogRectCorner | 弹窗视图的圆角 可单独设置或者全部设置 默认无 和UIRectCorner用法相同 多了一个none |
DialogTypeDown
DialogTypeDown参数 | 类型 | 作用 (默认值) |
---|---|---|
wImageSize | CGSize | 图片的大小 default (50,50) |
wImageName | NSString | 图片路径名字 default - |
wProgressTintColor | UIColor | 进度条闲置时候的颜色 default 0xFF9900 |
wTrackTintColor | UIColor | 进度条动作时候的颜色 default 0xF3F4F6 |
DialogTypeMenusSelect
DialogTypeMenusSelect参数 | 类型 | 作用 (默认值) |
---|---|---|
wTableViewColor | NSArray | tableview的背景颜色 default FFFFFF/F6F7FA/EBECF0/666666 |
DialogTypeLocation
DialogTypeLocation参数 | 类型 | 作用 (默认值) |
---|---|---|
wLocationType | NSInteger | 地区关联层级 default 3 |
wChainType | ChainType | 关联层级的样式 default ChainPickView |
wSeparator | NSString | 选中数据的分隔符 default , |
DialogTypeDatePicker
DialogTypeDatePicker参数 | 类型 | 作用 (默认值) |
---|---|---|
wDateTimeType | NSString | 时间选择器样式 yyyy年MM月dd日HH时mm分ss秒(自由组合) default yyyy:MM:dd HH:mm:ss |
wPickRepeat | BOOL | pickView无限循环 default YES |
wDefaultDate | NSDate | 默认选中时间 default 当前时间 |
Share/tabbarMenu/NaviMENU
Share/tabbarMenu/NaviMENU参数 | 类型 | 作用 (默认值) |
---|---|---|
wColumnCount | NSInteger | 列 default - |
wRowCount | NSInteger | 行 default - |
注意如果设置了行和列 要如期显示 要设置好wHeight |
DialogTypeLoading
DialogTypeLoading参数 | 类型 | 作用 (默认值) |
---|---|---|
wLoadingType | LoadingStyle | 加载框样式 default LoadingStyleWait |
wLoadingSize | CGSize | 加载框size default (90,90) |
wLoadingColor | UIColor | 加载框线条颜色 default 确定按钮的文本颜色 |
DialogTypeCardPresent
DialogTypeCardPresent参数 | 类型 | 作用 (默认值) |
---|---|---|
wOpenScrollClose | BOOL | 滑动到顶部继续滑动可关闭 default YES |
wLeftScrollClose | BOOL | 测滑可关闭 default YES |
wOpenDragging | BOOL | 开启拖动 default YES |
wScaleParentVC | BOOL | 缩放底部控制器 default YES |
wParentHeadView | - | 自定义顶部视图 default - |
wParentBottomView | - | 自定义底部视图 default - |
DialogTypeCalander
DialogTypeCalander参数 | 类型 | 作用 (默认值) |
---|---|---|
wDirectionVertical | BOOL | 开启纵向滑动 default NO(横向滑动) |
wCalanderCanScroll | BOOL | 开启滑动 default YES |
wOpenChineseDate | BOOL | 开启农历节日显示 default YES |
wHideCalanderBtn | BOOL | 隐藏日历上的操作按钮 default YES |
wDateShowCircle | NSArray | 展示圆点的日期@[[NSDate date]] default - |
wReginerCollectionCell | NSString | 注册自定义的collectionViewCell default - |
DialogTypeMyView
DialogTypeMyView参数 | 类型 | 作用 (默认值) |
---|---|---|
wAddBottomView | BOOL | 是否添加底部按钮 default NO |
Events
Events | 作用 (默认值) |
---|---|
wEventOKFinish | 确定点击事件 |
wEventCancelFinish | 取消点击事件(不传默认没有取消按钮) |
wEventFinish | 所有的操作事件 |
wEventClose | 弹窗关闭事件 |
wEventMenuClick | 菜单点击事件 |
wSelectCell | 自定义cell点击 |
wMyCell | 自定义cell |
wMyDiaLogView | 自定义弹窗View(返回最底部的view) |
wCalanderCell | 自定义日历cell |
wCalanderCellClick | 自定义日历点击 |
用法
默认模式
Dialog().wTypeSet(DialogTypeNornal).wStart();
多选模式
Dialog().wTypeSet(type)
.wEventOKFinishSet(^(id anyID, id otherData) {
NSLog(@"%@",anyID);
})
//出现动画
.wShowAnimationSet(AninationCombineTwo)
.wTitleSet(@"")
.wMultipleSelectionSet(YES).wSelectShowCheckedSet(YES)
.wDataSet(@[@"游泳",@"打篮球",@"打羽毛球",@"爬山",@"踢足球",@"乒乓球"])
.wStart();
自定义弹窗(优酷) 更多自定义弹窗看demo
myAlert = Dialog()
.wTypeSet(DialogTypeMyView)
//关闭事件 此时要置为不然会内存泄漏
.wEventCloseSet(^(id anyID, id otherData) {
myAlert = nil;
})
.wShowAnimationSet(AninatonZoomIn)
.wHideAnimationSet(AninatonZoomOut)
.wMyDiaLogViewSet(^UIView *(UIView *mainView) {
UIImageView *image = [UIImageView new];
image.image = [UIImage imageNamed:@"healthy"];
image.frame = CGRectMake(0, 0, mainView.frame.size.width, 80);
[mainView addSubview:image];
UILabel *la = [UILabel new];
la.font = [UIFont systemFontOfSize:15.0f];
la.text = @"为呵护未成年人健康成长,优酷特别推出青少年模式,该模式下部分功能无法正常使用,请监护人主动选择,并设置监护密码";
la.numberOfLines = 0;
la.frame = CGRectMake(10, CGRectGetMaxY(image.frame), mainView.frame.size.width-20, 100);
[mainView addSubview:la];
UIButton *enter = [UIButton buttonWithType:UIButtonTypeCustom];
[mainView addSubview:enter];
enter.titleLabel.font = [UIFont systemFontOfSize:14.0f];
enter.frame = CGRectMake(0, CGRectGetMaxY(la.frame), mainView.frame.size.width, 44);
[enter setTitle:@"进入青少年模式 >" forState:UIControlStateNormal];
[enter setTitleColor:DialogColor(0x108ee9) forState:UIControlStateNormal];
[enter addTarget:WEAK action:@selector(youkuAction:) forControlEvents:UIControlEventTouchUpInside];
UIButton *know = [UIButton buttonWithType:UIButtonTypeCustom];
[mainView addSubview:know];
know.titleLabel.font = [UIFont systemFontOfSize:14.0f];
know.frame = CGRectMake(0, CGRectGetMaxY(enter.frame), mainView.frame.size.width, 44);
[know setTitle:@"我知道了" forState:UIControlStateNormal];
[know setTitleColor:DialogColor(0x3333333) forState:UIControlStateNormal];
[know addTarget:WEAK action:@selector(youkuAction:) forControlEvents:UIControlEventTouchUpInside];
mainView.layer.masksToBounds = YES;
mainView.layer.cornerRadius = 10;
return know;
})
.wStart();
其他模式看demo
依赖
无任何依赖
安装
CocoaPods
- 将 cocoapods 更新至最新版本.
- 在 Podfile 中添加
pod 'WMZDialog',inhibit_warnings: true
(可消除警告)。或 pod 'WMZDialog' , '~>1.2.5' - 执行
pod install
或pod update
。 - 导入 #import "WMZDialog.h"。
注:要消除链式编程的警告
要在Buildding Settings 把CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF 设为NO Podfile里加inhibit_warnings: true 也可消除警告
手动安装
- 下载 WMZDialog 文件夹内的所有内容。
- 将 WMZDialog 内的源文件添加(拖放)到你的工程。
- 导入 #import "WMZDialog.h"
系统要求
该库最低支持 iOS 9.0
和 Xcode 9.0
。
许可证
WMZDialog 使用 MIT 许可证,详情见 LICENSE 文件。
个人主页
使用过程中如果有什么bug欢迎给我提issue 我看到就会解决 我的简书 ios问题交流群 937909825(有问题加群哈)
更新日记
- 20191005 优化代码修复地区弹窗bug
- 20191105 修改自动消失的样式 可支持图文
- 20191107 新增日历弹窗
- 20191108 新增ios13 present弹窗
- 20191109 cocopod 更新至 1.0.1
- 20191112 新增wDefaultDate属性 表示默认选中时间 default 当前时间
- 20191113 cocopod 更新至 1.0.2 修复pod指定ios版本的问题
- 20191124 cocopod 更新至 1.0.3 修复pod 版本过低导致出现weak的问题
- 20191214 cocopod 更新至 1.0.4 修复ios9.0某个type闪退问题和增加normalType确定或取消文字过多自动换行
- 20191216 cocopod 更新至 1.0.5 修复ios10崩溃问题
- 20191223 优化pop弹窗类型 支持圆角的定制 支持tableview等滚动视图的弹出
- 20191225 优化日期选择弹窗类型 1 新增最大和最小时间支持超出隐藏 2 新增日期选择格式化输出 3 修复弹窗嵌套的bug 4 cocopod更新至1.0.6(建议更新)
- 20200107 cocopod 更新至 1.0.7 修复日期选择的bug 修复pop弹窗的bug 修复presentCard弹窗的bug
- 20200117 cocopod 更新至 1.1.0 过年更新一波bug
- 20200519 cocopod 更新至 1.1.2 优化一些地方
- 20200606 cocopod 更新至 1.1.3 新增wTag可防止重复点击 新增自定义frame的方法
- 20200828 cocopod 更新至 1.1.5 新增列表默认选中的属性
- 20200920 cocopod 更新至 1.1.6 适配ios14
- 20200929 cocopod 更新至 1.1.7 时间好快又国庆了,国庆放假前更新一波 支持地区/拾取器/多级菜单 除了关于时间的默认选中用wDefaultDate,其他使用wListDefaultValue
- 20201009 cocopod 更新至 1.1.8 修复bug
- 20201118 cocopod 更新至 1.1.9 新增阴影点击回调 新增自定义地区数据
- 20201218 cocopod 更新至 1.1.10 修复ios14无法弹出的问题
- 20201221 cocopod 更新至 1.2.0 日历弹窗新增连续区域 pop弹窗修复bug+新增自定义三角形size
- 20210105 cocopod 更新至 1.2.1 日历弹窗新增多个连续区域 支持横开启屏监听wDeviceDidChange 优化列表选项
- 20210107 cocopod 更新至 1.2.3 优化选择弹窗 解决pod里没有xib文件导致报错的问题
- 20210113 cocopod 更新至 1.2.4 优化静态库xib问题 LoadingType优化 可作为项目的loading框使用
- 20210202 cocopod 更新至 1.2.5 优化LoadingType 又是一年过年了 真快
Note that the project description data, including the texts, logos, images, and/or trademarks,
for each open source project belongs to its rightful owner.
If you wish to add or remove any projects, please contact us at [email protected].