您的位置:首页 > 产品设计 > UI/UE

iOS8 UIAlertView 和 UIActionSheet 的新用法 UIAlertController详解

2016-07-30 11:29 429 查看
 添加了新的类 UIAlertController 和 UIAlertAction 来取代曾经的 UIAlertView 和 UIActionSheet,感觉警告窗口的结构更容易理解了,使用起来也更简便。但是曾经用 Xcode 5 创建过 iOS 7程序在iOS
8 设备上运行就会出现各种问题。我清晰地记得刚刚升级 iOS 8 后连微信的警示操作表也出了问题,猜测可能是因此而起的。 

       下面来看看UIAlertController 和  UIAlertAction 用法:

1. 最简单的提醒视图:

       这里我们实现一个最简单的提醒视图,包含1个标题,1行信息,1个按键,按下按键后,什么都不发生:

[objc] view
plain copy

- (IBAction)doAlert:(id)sender {  

    // 准备初始化配置参数  

    NSString *title = @"Alert Button Selected";  

    NSString *message = @"I need your attention NOW!";  

    NSString *okButtonTitle = @"OK";  

      

    // 初始化  

    UIAlertController *alertDialog = [UIAlertController alertControllerWithTitle:title message:message preferredStyle:UIAlertControllerStyleAlert];  

      

    // 创建操作  

    UIAlertAction *okAction = [UIAlertAction actionWithTitle:okButtonTitle style:UIAlertActionStyleDefault handler:^(UIAlertAction *action) {  

        // 操作具体内容  

        // Nothing to do.  

    }];  

      

    // 添加操作  

    [alertDialog addAction:okAction];  

      

    // 呈现警告视图  

    [self presentViewController:alertDialog animated:YES completion:nil];  

}  

       进入程序后,点击“Alert Me!”按钮可触发这个提醒框,如图所示:



       从代码可以看出,新的API更加符合逻辑,有种需要什么就加什么的感觉。

2. 多个按键的提醒视图

       这里我们实现一个最简单的提醒视图,包含1个标题,1行信息,3个按键,按下按键后,标签显示按下的按键名称:

[objc] view
plain copy

- (IBAction)doMultiButtonAlert:(id)sender {  

    // 准备初始化配置参数  

    NSString *title = @"Alert Button Selected";  

    NSString *message = @"I need your attention NOW!";  

    NSString *okButtonTitle = @"OK";  

    NSString *neverButtonTitle = @"Never";  

    NSString<
1c140
span style="margin:0px;padding:0px;border:none;background-color:inherit;"> *laterButtonTitle = @"Maybe Later";  

      

    // 初始化  

    UIAlertController *alertDialog = [UIAlertController alertControllerWithTitle:title message:message preferredStyle:UIAlertControllerStyleAlert];  

      

    // 分别3个创建操作  

    UIAlertAction *laterAction = [UIAlertAction actionWithTitle:laterButtonTitle style:UIAlertActionStyleDefault handler:^(UIAlertAction *action) {  

        // 普通按键  

        self.userOutput.text = @"Clicked 'Maybe Later'";  

    }];  

    UIAlertAction *neverAction = [UIAlertAction actionWithTitle:neverButtonTitle style:UIAlertActionStyleDestructive handler:^(UIAlertAction *action) {  

        // 红色按键  

        self.userOutput.text = @"Clicked 'Never'";  

    }];  

    UIAlertAction *okAction = [UIAlertAction actionWithTitle:okButtonTitle style:UIAlertActionStyleCancel handler:^(UIAlertAction *action) {  

        // 取消按键  

        self.userOutput.text = @"Clicked 'OK'";  

    }];  

      

    // 添加操作(顺序就是呈现的上下顺序)  

    [alertDialog addAction:laterAction];  

    [alertDialog addAction:neverAction];  

    [alertDialog addAction:okAction];  

      

    // 呈现警告视图  

    [self presentViewController:alertDialog animated:YES completion:nil];  

}  

       3个按键分别代表了3种不同类型的按键,分别是默认按键(普通)、销毁按键(红色)和取消按键(粗体)。从代码看其实就是在上一个的基础上加了3个 UIAlertAction 而已,然后分别设置不同的 style,效果如下:



3. 带输入框的提醒视图

       如何添加输入框呢?新的 iOS 8 提供了相应的接口,使增加输入框就像增加按键方法一样简单。这里还是在第1个方法的基础上改动。

[objc] view
plain copy

- (IBAction)doAlertInput:(id)sender {  

    // 准备初始化配置参数  

    NSString *title = @"Email Address";  

    NSString *message = @"Please enter your your email address:";  

    NSString *okButtonTitle = @"OK";  

      

    // 初始化  

    UIAlertController *alertDialog = [UIAlertController alertControllerWithTitle:title message:message preferredStyle:UIAlertControllerStyleAlert];  

      

    // 创建文本框  

    [alertDialog addTextFieldWithConfigurationHandler:^(UITextField *textField){  

        textField.placeholder = @"Your Email";  

        textField.secureTextEntry = NO;  

    }];  

      

    // 创建操作  

    UIAlertAction *okAction = [UIAlertAction actionWithTitle:okButtonTitle style:UIAlertActionStyleDefault handler:^(UIAlertAction *action) {  

        // 读取文本框的值显示出来  

        UITextField *userEmail = alertDialog.textFields.firstObject;  

        self.userOutput.text = userEmail.text;  

    }];  

      

    // 添加操作(顺序就是呈现的上下顺序)  

    [alertDialog addAction:okAction];  

      

    // 呈现警告视图  

    [self presentViewController:alertDialog animated:YES completion:nil];  

}  

       在创建操作前先创建文本框,以便后面的按键可以操作文本框内容。创建文本框也只是用了一个简单的方法而已,想创建更多文本框就再使用多次这个方法即可,程序效果如下:



4. 提醒图表

       与第2个和第3个方法相比,创建提醒图表简直易如反掌。因为和第1个方法相比,只需要改动一个参数就可以,即把创建UIAlertController实例的参数 UIAlertControllerStyleAlert 改为 UIAlertControllerStyleActionSheet ,别的都不用变。

[objc] view
plain copy

- (IBAction)doActionSheet:(id)sender {  

    // 准备初始化配置参数  

    NSString *title = @"Alert Button Selected";  

    NSString *message = @"I need your attention NOW!";  

    NSString *okButtonTitle = @"OK";  

    NSString *neverButtonTitle = @"Never";  

    NSString *laterButtonTitle = @"Maybe Later";  

      

    // 初始化  

    UIAlertController *alertDialog = [UIAlertController alertControllerWithTitle:title message:message preferredStyle:UIAlertControllerStyleActionSheet];  

      

    // 分别3个创建操作  

    UIAlertAction *laterAction = [UIAlertAction actionWithTitle:laterButtonTitle style:UIAlertActionStyleDefault handler:^(UIAlertAction *action) {  

        // 普通按键  

        self.userOutput.text = @"Clicked 'Maybe Later'";  

    }];  

    UIAlertAction *neverAction = [UIAlertAction actionWithTitle:neverButtonTitle style:UIAlertActionStyleDestructive handler:^(UIAlertAction *action) {  

        // 红色按键  

        self.userOutput.text = @"Clicked 'Never'";  

    }];  

    UIAlertAction *okAction = [UIAlertAction actionWithTitle:okButtonTitle style:UIAlertActionStyleCancel handler:^(UIAlertAction *action) {  

        // 取消按键  

        self.userOutput.text = @"Clicked 'OK'";  

    }];  

      

    // 添加操作(顺序就是呈现的上下顺序)  

    [alertDialog addAction:laterAction];  

    [alertDialog addAction:neverAction];  

    [alertDialog addAction:okAction];  

      

    // 呈现警告视图  

    [self presentViewController:alertDialog animated:YES completion:nil];  

}  

       这个就很简单了,跟第2个方法很像,效果如图:



5. 播放系统声音、提醒声音和振动设备

       在 iOS 8 中,调用声音的方法发生了小变化,用曾经的方式无法获取系统声音文件的 soundID 。因此,这里直接调用 soundID 值来调用对应的声音,注意振动仍然正常调用kSystemSoundID_Vibrate常量即可:

[objc] view
plain copy

- (IBAction)doSound:(id)sender {  

    // 播放系统声音  

    AudioServicesPlaySystemSound(1005);  

}  

  

- (IBAction)doAlertSound:(id)sender {  

    // 播放提醒声音  

    AudioServicesPlayAlertSound(1006);  

}  

  

- (IBAction)doVibration:(id)sender {  

    // 执行震动  

    AudioServicesPlaySystemSound(kSystemSoundID_Vibrate);  

}  

       这样在 iOS 8 中就可以对用户发出提示了。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息