黑马程序员技术交流社区
标题: 【武汉校区】技术分享:UIAlertView [打印本页]
作者: 武汉分校-小舞 时间: 2016-4-5 11:33
标题: 【武汉校区】技术分享:UIAlertView
【武汉校区】技术分享:UIAlertView
1.Title获取或设置UIAlertView上的标题。
2.Message获取或设置UIAlertView上的消息
UIAlertView *alertView = [[UIAlertView alloc] initWithTitleundefined"Title" messageundefined"message" delegate:self cancelButtonTitleundefined"取消" otherButtonTitlesundefined"确定", nil];
alertView.title = @"T";
alertView.message = @"M";
[alertView show];
3.numberOfButtons (只读)返回UIAlertView上有多少按钮.
UIAlertView *alertView = [[UIAlertView alloc] initWithTitleundefined"Title" messageundefined"message" delegate:self cancelButtonTitleundefined"取消" otherButtonTitlesundefined"确定", nil];
NSLog(@"%d",alertView.numberOfButtons);
[alertView show];
4.cancelButtonIndex UIAlertView *alert = [[UIAlertView alloc]initWithTitleundefined"提示"
messageundefined"请选择一个按钮:"
delegate:nil
cancelButtonTitle:@"取消"
otherButtonTitles:@"按钮一", @"按钮二", @"按钮三",nil];
[alert show];
NSLog(@"UIAlertView中取消按钮的角标是%d",alert.cancelButtonIndex);
效果:
注意不要认为取消按钮的角标是4,“取消”,“按钮一”,“按钮二”,“按钮三”的索引buttonIndex分别是0,1,2,3
5. alertViewStyle
5.1 UIAlertViewStyleLoginAndPasswordInputUIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"产品信息展示" message:p.name delegate:nil cancelButtonTitle:@"取消" otherButtonTitles:@"确定", nil];
alert.alertViewStyle = UIAlertViewStyleLoginAndPasswordInput;
// 弹出UIAlertView
[alert show];
5.2 UIAlertViewStylePlainTextInputUIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"产品信息展示" message:p.name delegate:nil cancelButtonTitle:@"取消" otherButtonTitles:@"确定", nil];
alert.alertViewStyle = UIAlertViewStylePlainTextInput;
// 弹出UIAlertView
[alert show];
5.3UIAlertViewStyleSecureTextInputUIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"产品信息展示" message:p.name delegate:nil cancelButtonTitle:@"取消" otherButtonTitles:@"确定", nil];
alert.alertViewStyle = UIAlertViewStyleSecureTextInput;
// 弹出UIAlertView
[alert show];
6. - (UITextField *)textFieldAtIndexundefinedNSInteger)textFieldIndex返回textFieldIndex角标对应的文本框。
取出文本框文字
7.手动的取消对话框[alert dismissWithClickedButtonIndex:0 animated:YES];
8. delegate作为UIAlertView的代理,必须遵守UIAlertViewDelegate。
1.当点击UIAlertView上的按钮时,就会调用,并且当方法调完后,UIAlertView会自动消失。- (void)alertViewundefinedUIAlertView *)alertView clickedButtonAtIndexundefinedNSInteger)buttonIndex;
2.当UIAlertView即将出现的时候调用- (void)willPresentAlertViewundefinedUIAlertView *)alertView;
3. 当UIAlertView完全出现的时候调用- (void)didPresentAlertViewundefinedUIAlertView *)alertView;
4. 当UIAlertView即将消失的时候调用- (void)alertViewundefinedUIAlertView *)alertView willDismissWithButtonIndexundefinedNSInteger)buttonIndex;
5. 当UIAlertView完全消失的时候调用- (void)alertViewundefinedUIAlertView *)alertView didDismissWithButtonIndexundefinedNSInteger)buttonIndex;
9.注意UIAlertView调用show显示出来的时候,系统会自动强引用它,不会被释放。
10. 为UIAlertView添加子视图在为UIAlertView对象太添加子视图的过程中,有点是需要注意的地方,如果删除按钮,也就是取消UIAlerView视图中所有的按钮的时候,可能会导致整个显示结构失衡。按钮占用的空间不会消失,我们也可以理解为这些按钮没有真正的删除,仅仅是他不可见了而已。如果在UIAlertview对象中仅仅用来显示文本,那么,可以在消息的开头添加换行符(@"\n)有助于平衡按钮底部和顶部的空间。
下面的代码用来演示如何为UIAlertview对象添加子视图的方法。
UIAlertView*alert = [[UIAlertView alloc]initWithTitle:@"请等待"
message:nil
delegate:nil
cancelButtonTitle:nil
otherButtonTitles:nil];
[alert show];
UIActivityIndicatorView*activeView = [[UIActivityIndicatorView alloc]initWithActivityIndicatorStyle:UIActivityIndicatorViewStyleWhiteLarge];
activeView.center = CGPointMake(alert.bounds.size.width / 2.0f, alert.bounds.size.height - 40.0f);
[activeView startAnimating];
[alert addSubview:activeView];
11. UIAlertView小例子 UIAlertView默认情况下所有的text是居中对齐的。 那如果需要将文本向左对齐或者添加其他控件比如输入框时该怎么办呢? 不用担心, iPhone SDK还是很灵活的, 有很多delegate消息供调用程序使用。 所要做的就是在
- (void)willPresentAlertViewundefinedUIAlertView *)alertView
中按照自己的需要修改或添加即可, 比如需要将消息文本左对齐,下面的代码即可实现:
-(void) willPresentAlertView:(UIAlertView *)alertView
{
for( UIView * view in alertView.subviews )
{
if( [view isKindOfClass:[UILabel class]] )
{
UILabel* label = (UILabel*) view;
label.textAlignment=UITextAlignmentLeft;
}
}
}
想获取最新传智播客武汉中心分享技术文章请加QQ 1641907557 ,后期会分享更多与实体班同步教程,助你冲击月薪20K!
推荐阅读:
作者: 蒂尔 时间: 2016-4-13 10:14
谢谢分享
作者: 84345992 时间: 2016-4-13 11:12
谢谢分享`
作者: Latinno 时间: 2016-4-15 16:33
UI的帖子得慢慢看啊,内容太多了。
感谢分享。
作者: ySssssssss 时间: 2016-4-16 23:59
感谢分享
作者: 妖精的尾巴_wzn 时间: 2016-5-6 22:58
好强大啊,不服不行。感谢分享。
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) |
黑马程序员IT技术论坛 X3.2 |