配色: 字号:
iOS中UIAlertView警告框组件的使用教程
2016-11-04 | 阅:  转:  |  分享 
  
iOS中UIAlertView警告框组件的使用教程



需要注意的是在IOS8之后,UIAlertView和UIActionSheet这两个控件被UIAlertController代替,但是这两个控件依然可以使,下面我们就简单了解一下iOS中UIAlertView警告框组件的使用教程

1.最简单的用法

初始化方法:





复制代码代码如下:





-(instancetype)initWithTitle:(NSString)titlemessage:(NSString)messagedelegate:(id//)delegatecancelButtonTitle:(NSString)cancelButtonTitleotherButtonTitles:(NSString)otherButtonTitles,...;





这个方法通过设置一个标题,内容,代理和一些按钮的标题创建警告框,代码示例如下:

UIAlertViewalert=[[UIAlertViewalloc]initWithTitle:@"我的警告框"message:@"这是一个警告框"delegate:selfcancelButtonTitle:@"取消"otherButtonTitles:@"确定",nil];

[alertshow];

效果如下:





















注意:如果按钮数超过两个,将会创建成如下样子:





















如果按钮数量超出屏幕显示范围,则会创建类似tableView的效果。



2.为UIAlertView添加多个按钮





复制代码代码如下:





UIAlertViewalert=[[UIAlertViewalloc]initWithTitle:@"提示"



message:@"请选择一个按钮:"



delegate:nil



cancelButtonTitle:@"取消"



otherButtonTitles:@"按钮一",@"按钮二",@"按钮三",nil];



[alertshow];



[alertrelease];







3.如何判断用户点击的按钮

UIAlertView有一个委托(代理)UIAlertViewDelegate,继承该委托来实现点击事件



头文件:





复制代码代码如下:





@interfaceMyAlertViewViewController:UIViewController{



}



(void)alertView:(UIAlertView)alertViewclickedButtonAtIndex:(NSInteger)buttonIndex;

-(IBAction)buttonPressed;



@end





源文件:



复制代码代码如下:





-(IBAction)buttonPressed



{



UIAlertViewalert=[[UIAlertViewalloc]initWithTitle:@"提示"



message:@"请选择一个按钮:"



delegate:self



cancelButtonTitle:@"取消"



otherButtonTitles:@"按钮一",@"按钮二",@"按钮三",nil];



[alertshow];



[alertrelease];



}



(void)alertView:(UIAlertView)alertViewclickedButtonAtIndex:(NSInteger)buttonIndex

{



NSStringmsg=[[NSStringalloc]initWithFormat:@"您按下的第%d个按钮!",buttonIndex];



UIAlertViewalert=[[UIAlertViewalloc]initWithTitle:@"提示"



message:msg



delegate:nil



cancelButtonTitle:@"确定"



otherButtonTitles:nil];



[alertshow];



[alertrelease];



[msgrelease];



}





点击“取消”,“按钮一”,“按钮二”,“按钮三”的索引buttonIndex分别是0,1,2,3



4.手动的取消对话框





复制代码代码如下:





[alertdismissWithClickedButtonIndex:0animated:YES];







5.为UIAlertView添加子视图

在为UIAlertView对象太添加子视图的过程中,有点是需要注意的地方,如果删除按钮,也就是取消UIAlerView视图中所有的按钮的时候,可能会导致整个显示结构失衡。按钮占用的空间不会消失,我们也可以理解为这些按钮没有真正的删除,仅仅是他不可见了而已。如果在UIAlertview对象中仅仅用来显示文本,那么,可以在消息的开头添加换行符(@"\n)有助于平衡按钮底部和顶部的空间。



下面的代码用来演示如何为UIAlertview对象添加子视图的方法。





复制代码代码如下:





UIAlertViewalert=[[UIAlertViewalloc]initWithTitle:@"请等待"



message:nil



delegate:nil



cancelButtonTitle:nil



otherButtonTitles:nil];



[alertshow];



UIActivityIndicatorViewactiveView=[[UIActivityIndicatorViewalloc]initWithActivityIndicatorStyle:UIActivityIndicatorViewStyleWhiteLarge];



activeView.center=CGPointMake(alert.bounds.size.width/2.0f,alert.bounds.size.height-40.0f);



[activeViewstartAnimating];



[alertaddSubview:activeView];



[activeViewrelease];



[alertrelease];







6.其他

UIAlertView默认情况下所有的text是居中对齐的。那如果需要将文本向左对齐或者添加其他控件比如输入框时该怎么办呢?不用担心,iPhoneSDK还是很灵活的,有很多delegate消息供调用程序使用。所要做的就是在





复制代码代码如下:





(void)willPresentAlertView:(UIAlertView)alertView





中按照自己的需要修改或添加即可,比如需要将消息文本左对齐,下面的代码即可实现:



复制代码代码如下:





-(void)willPresentAlertView:(UIAlertView)alertView



{



for(UIViewviewinalertView.subviews)



{



if([viewisKindOfClass:[UILabelclass]])



{



UILabellabel=(UILabel)view;



label.textAlignment=UITextAlignmentLeft;



}



}



}





这段代码很简单,就是在消息框即将弹出时,遍历所有消息框对象,将其文本对齐属性修改为UITextAlignmentLeft即可。



添加其他部件也如出一辙,如下代码添加两个UITextField:





复制代码代码如下:





-(void)willPresentAlertView:(UIAlertView)alertView



{



CGRectframe=alertView.frame;



frame.origin.y-=120;



frame.size.height+=80;



alertView.frame=frame;



for(UIViewviewinalertView.www.visa158.com.subviews)



{



if(![viewisKindOfClass:[UILabelclass]])



{



CGRectbtnFrame=view.frame;



btnFrame.origin.y+=70;



view.frame=btnFrame;



}



}



UITextFieldaccoutName=[[UITextFieldalloc]init];



UITextFieldaccoutPassword=[[UITextFieldalloc]init];



accoutName.frame=CGRectMake(10,frame.origin.y+40,frame.size.width-20,30);



accoutPassword.frame=CGRectMake(10,frame.origin.y+80,frame.size.width-20,30);



accoutName.placeholder=@"请输入账号";



accoutPassword.placeholder=@"请输入密码";



accoutPassword.secureTextEntry=YES;



[alertViewaddSubview:accoutPassword];



[alertViewaddSubview:accoutName];



[accoutNamerelease];



[accoutPasswordrelease];



}





显示将消息框固有的button和label移位,不然添加的textfield会将其遮盖住。然后添加需要的部件到相应的位置即可。



对于UIActionSheet其实也是一样的,在





复制代码代码如下:





(void)willPresentActionSheet:(UIActionSheet)actionSheet





中做同样的处理一样可以得到自己想要的界面。























献花(0)
+1
(本文系白狐一梦首藏)