博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
自定义AlertView实现模态对话框
阅读量:2398 次
发布时间:2019-05-10

本文共 3127 字,大约阅读时间需要 10 分钟。

原文地址:http://www.189works.com/article-57077-1.html
摘要: 在Windows应用程序中,经常使用模态(Model)对话框来和用户进行简单的交互,比如登录框。在IOS应用程序中,有时我们也希望做同样的事情。但IOS的UI库中,没有模态对话框,最接近那个样子的应该算是AlertView。但仅用A ...

在Windows应用程序中,经常使用模态(Model)对话框来和用户进行简单的交互,比如登录框。
应用程序中,有时我们也希望做同样的事情。但IOS的UI库中,没有模态对话框,最接近那个样子的应该算是AlertView。
但仅用AlertView,我们只能做文字提示,而不能和用户做交互。

本文将介绍如何基于AlertView做定制,实现模态对话框的功能。以密码修改框为例:

1. 首先,我们要继承AlertView类,在类的头文件PwdModifyView.h中,加入控件的声明
    这里我们把控件都声明为property,目的是让外部的类可以访问用户输入的数据。

#import @interface PwdModifyView : UIAlertView@property(nonatomic, retain) UITextField* _oldPwd;    // 旧密码输入框@property(nonatomic, retain) UITextField* _newPwd;    // 新密码输入框@property(nonatomic, retain) UITextField* _cfmPwd;    // 新密码确认框@end

2. 在PwdModifyView.m文件中,需要实现两个函数

- (id)initWithTitle:(NSString *)title message:(NSString *)message delegate:(id)delegate cancelButtonTitle:(NSString *)cancelButtonTitle otherButtonTitles:(NSString *)otherButtonTitles, ... {    self = [super initWithTitle:title message:message delegate:delegate cancelButtonTitle:cancelButtonTitle otherButtonTitles:otherButtonTitles, nil];    if (self != nil) {        // 初始化自定义控件,注意摆放的位置,可以多试几次位置参数直到满意为止        // createTextField函数用来初始化UITextField控件,在文件末尾附上        self._oldPwd = [self createTextField:@"旧密码"                                   withFrame:CGRectMake(22, 45, 240, 36)];        [self addSubview:self._oldPwd];                self._newPwd = [self createTextField:@"新密码"                                   withFrame:CGRectMake(22, 90, 240, 36)];        [self addSubview:self._newPwd];                self._cfmPwd = [self createTextField:@"确认新密码"                                   withFrame:CGRectMake(22, 135, 240, 36)];        [self addSubview:self._cfmPwd];    }        return self;}
// Override父类的layoutSubviews方法- (void)layoutSubviews {    [super layoutSubviews];     // 当override父类的方法时,要注意一下是否需要调用父类的该方法        for (UIView* view in self.subviews) {        // 搜索AlertView底部的按钮,然后将其位置下移        // 以前按钮类是UIButton, IOS5里该按钮类是UIThreePartButton        if ([view isKindOfClass:[UIButton class]] ||            [view isKindOfClass:NSClassFromString(@"UIThreePartButton")]) {            CGRect btnBounds = view.frame;            btnBounds.origin.y = self._cfmPwd.frame.origin.y + self._cfmPwd.frame.size.height + 7;            view.frame = btnBounds;        }    }        // 定义AlertView的大小    CGRect bounds = self.frame;    bounds.size.height = 260;    self.frame = bounds;}

3. 当需要弹出该对话框时,只需创建并初始化一个PwdModifyView对象,然后调用对象的show()方法即可。

PwdModifyDlg* pwdModifyDlg = [[PwdModifyView alloc]                     initWithTitle:@"密码修改"                     message:nil                     delegate:self                     cancelButtonTitle:@"确定"                     otherButtonTitles:@"取消", nil];[pwdModifyDlg show];

 

最后,附上UITextField的创建函数

- (UITextField*)createTextField:(NSString*)placeholder withFrame:(CGRect)frame {    UITextField* field = [[UITextField alloc] initWithFrame:frame];    field.placeholder = placeholder;    field.secureTextEntry = YES;    field.backgroundColor = [UIColor whiteColor];     field.contentVerticalAlignment = UIControlContentVerticalAlignmentCenter;    return field;}

转载地址:http://ubuob.baihongyu.com/

你可能感兴趣的文章
hiho一下 第四十四周 题目1 : 博弈游戏·Nim游戏
查看>>
poj2299 Ultra-QuickSort(线段树计数问题)
查看>>
hdu4565 So Easy!(矩阵快速幂)
查看>>
poj2528 Mayor's posters(线段树,离散化)
查看>>
线段树多lazy-tag(两个)
查看>>
hdu4578(三个更新操作,三个求值操作)
查看>>
并查集(初级)小结
查看>>
Treap
查看>>
计算机系统结构 计算机指令集结构
查看>>
计算机系统结构 输入/输出系统
查看>>
信息安全技术及应用 常规加密技术
查看>>
02-线性结构1 两个有序链表序列的合并
查看>>
HDU 1080 DP LCS
查看>>
HDU 3308 线段树+区间合并
查看>>
ASP.NET 入手页面控件及事件触发
查看>>
HDU 4123 树状DP+RMQ
查看>>
vim配置文件(持续更新)
查看>>
Fedora 16下添加终端快捷键
查看>>
HDU 4001 DP LIS
查看>>
HDU 4023 贪心+博弈
查看>>