iOS自定義alertView提示框?qū)嵗窒?/h1>
更新時(shí)間:2016年04月21日 15:32:12 作者:菜鳥Alex
這是一款可以隨意改變彈框背景色,按鈕背景色,提示消息字體顏色的iOS alertView提示框,想要用于這樣一款alertView提示框的朋友不要錯(cuò)過
本文實(shí)例為大家分享iOS自定義alertView提示框,先上圖,彈框的背景色,按鈕背景色,提示的消息的字體顏色都可以改變

利用單例實(shí)現(xiàn)豐富的自定義接口
//
// PBAlertController.h
// PBAlertDemo
//
// Created by 裴波波 on 16/4/20.
// Copyright © 2016年 裴波波. All rights reserved.
//
#import <UIKit/UIKit.h>
typedef void(^PBBlock)();
@interface PBAlertController : UIViewController
/** 設(shè)置alertView背景色 */
@property (nonatomic, copy) UIColor *alertBackgroundColor;
/** 設(shè)置確定按鈕背景色 */
@property (nonatomic, copy) UIColor *btnConfirmBackgroundColor;
/** 設(shè)置取消按鈕背景色 */
@property (nonatomic, copy) UIColor *btnCancelBackgroundColor;
/** 設(shè)置message字體顏色 */
@property (nonatomic, copy) UIColor *messageColor;
/** 創(chuàng)建單例 */
+(instancetype)shareAlertController;
/** 彈出alertView以及點(diǎn)擊確定回調(diào)的block */
-(void)alertViewControllerWithMessage:(NSString *)message andBlock:(PBBlock) block;
@end
.m文件中初始化控件以及對(duì)alertView的控件的屬性進(jìn)行懶加載,確定初始的顏色.
//
// PBAlertController.m
// PBAlertDemo
//
// Created by 裴波波 on 16/4/20.
// Copyright © 2016年 裴波波. All rights reserved.
//
#import "PBAlertController.h"
/** 屏幕尺寸 */
#define kMainScreenBounds [UIScreen mainScreen].bounds
@interface PBAlertController ()
/** 蒙版 */
@property (nonatomic, strong) UIView *coverView;
/** 彈框 */
@property (nonatomic, strong) UIView *alertView;
/** 點(diǎn)擊確定回調(diào)的block */
@property (nonatomic, copy) PBBlock block;
@end
@implementation PBAlertController
- (void)viewDidLoad {
[super viewDidLoad];
self.view.backgroundColor = [UIColor whiteColor];
}
-(void)alertViewControllerWithMessage:(NSString *)message andBlock:(PBBlock) block{
self.block = block;
//創(chuàng)建蒙版
UIView * coverView = [[UIView alloc] initWithFrame:kMainScreenBounds];
self.coverView = coverView;
[self.view addSubview:coverView];
coverView.backgroundColor = [UIColor blackColor];
coverView.alpha = 0.7;
//創(chuàng)建提示框view
UIView * alertView = [[UIView alloc] init];
alertView.backgroundColor = self.alertBackgroundColor;
//設(shè)置圓角半徑
alertView.layer.cornerRadius = 6.0;
self.alertView = alertView;
[self.view addSubview:alertView];
alertView.center = coverView.center;
alertView.bounds = CGRectMake(0, 0, kMainScreenBounds.size.width * 0.75, kMainScreenBounds.size.width * 0.75 * 1.5/ 3);
//創(chuàng)建操作提示 label
UILabel * label = [[UILabel alloc] init];
[alertView addSubview:label];
label.text = @"操作提示";
label.font = [UIFont systemFontOfSize:19];
label.textAlignment = NSTextAlignmentCenter;
CGFloat lblWidth = alertView.bounds.size.width;
CGFloat lblHigth = 22;
label.frame = CGRectMake(0, 0, lblWidth, lblHigth);
//創(chuàng)建中間灰色分割線
UIView * separateLine = [[UIView alloc] init];
separateLine.backgroundColor = [UIColor grayColor];
[alertView addSubview:separateLine];
separateLine.frame = CGRectMake(0, lblHigth + 1, alertView.bounds.size.width, 1);
//創(chuàng)建message label
UILabel * lblMessage = [[UILabel alloc] init];
lblMessage.textColor = self.messageColor;
[alertView addSubview:lblMessage];
lblMessage.text = message;
lblMessage.textAlignment = NSTextAlignmentCenter;
lblMessage.numberOfLines = 2; //最多顯示兩行Message
CGFloat margin = 5;
CGFloat msgX = margin;
CGFloat msgY = lblHigth + 3;
CGFloat msgW = alertView.bounds.size.width - 2 * margin;
CGFloat msgH = 44;
lblMessage.frame = CGRectMake(msgX, msgY, msgW, msgH);
//創(chuàng)建確定 取消按鈕
CGFloat buttonWidth = (alertView.bounds.size.width - 4 * margin) * 0.5;
CGFloat buttonHigth = 25;
UIButton * btnCancel = [[UIButton alloc] init];
[alertView addSubview:btnCancel];
[btnCancel setTitleColor:[UIColor whiteColor] forState:UIControlStateNormal];
[btnCancel setTitle:@"取消" forState:UIControlStateNormal];
[btnCancel setBackgroundColor:self.btnCancelBackgroundColor];
btnCancel.frame = CGRectMake(margin, alertView.bounds.size.height - margin - buttonHigth, buttonWidth, buttonHigth);
btnCancel.tag = 0;
[btnCancel addTarget:self action:@selector(didClickBtnConfirm:) forControlEvents:UIControlEventTouchUpInside];
//確定按鈕
UIButton * btnConfirm = [[UIButton alloc] init];
btnConfirm.tag = 1;
[alertView addSubview:btnConfirm];
[btnConfirm setTitleColor:[UIColor whiteColor] forState:UIControlStateNormal];
[btnConfirm setTitle:@"確定" forState:UIControlStateNormal];
[btnConfirm setBackgroundColor:self.btnConfirmBackgroundColor];
btnConfirm.frame = CGRectMake(alertView.bounds.size.width - margin - buttonWidth, alertView.bounds.size.height - margin - buttonHigth, buttonWidth, buttonHigth);
[btnConfirm addTarget:self action:@selector(didClickBtnConfirm:) forControlEvents:UIControlEventTouchUpInside];
}
/** 點(diǎn)擊確定 or 取消觸發(fā)事件 */
-(void)didClickBtnConfirm:(UIButton *)sender{
if (sender.tag == 0) {
[self dismissViewControllerAnimated:YES completion:nil];
return;
}
self.block();
[self dismissViewControllerAnimated:YES completion:nil];
}
- (void)didReceiveMemoryWarning {
[super didReceiveMemoryWarning];
}
static PBAlertController * instance = nil;
+(instancetype)shareAlertController{
static dispatch_once_t onceToken;
dispatch_once(&onceToken, ^{
instance = [[PBAlertController alloc] init];
});
return instance;
}
-(UIColor *)alertBackgroundColor{
if (_alertBackgroundColor == nil) {
_alertBackgroundColor = [UIColor colorWithRed:249/255.0 green:249/255.0 blue:249/255.0 alpha:1];
}
return _alertBackgroundColor;
}
/** 確定按鈕背景色 */
-(UIColor *)btnConfirmBackgroundColor{
if (_btnConfirmBackgroundColor == nil) {
_btnConfirmBackgroundColor = [UIColor orangeColor];
}
return _btnConfirmBackgroundColor;
}
/** 取消按鈕背景色 */
-(UIColor *)btnCancelBackgroundColor{
if (_btnCancelBackgroundColor == nil) {
_btnCancelBackgroundColor = [UIColor blueColor];
}
return _btnCancelBackgroundColor;
}
/** message字體顏色 */
-(UIColor *)messageColor{
if (_messageColor == nil) {
_messageColor = [UIColor blackColor];
}
return _messageColor;
}
@end
在需要調(diào)用的地方進(jìn)行調(diào)用
//
// ViewController.m
// PBAlertDemo
//
// Created by 裴波波 on 16/4/20.
// Copyright © 2016年 裴波波. All rights reserved.
//
#import "ViewController.h"
#import "PBAlertController.h"
@interface ViewController ()
@end
@implementation ViewController
//點(diǎn)擊按鈕彈出提示框
- (IBAction)clickShowAlertBtn:(id)sender {
PBAlertController * alertVc = [PBAlertController shareAlertController];
alertVc.messageColor = [UIColor redColor];
[alertVc alertViewControllerWithMessage:@"這是一message沙哈" andBlock:^{
NSLog(@"點(diǎn)擊確定后執(zhí)行的方法");
}];
alertVc.modalTransitionStyle = UIModalTransitionStyleCrossDissolve;
[self presentModalViewController:alertVc animated:YES];
}
@end
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家學(xué)習(xí)iOS程序設(shè)計(jì)有所幫助。
您可能感興趣的文章:- iOS9提示框的正確使用方式
- iOS移動(dòng)端(H5)alert/confirm提示信息去除網(wǎng)址(URL)
- iOS自定義提示彈出框?qū)崿F(xiàn)類似UIAlertView的效果
- iOS自定義推送消息提示框
- Android仿IOS自定義AlertDialog提示框
- iOS實(shí)現(xiàn)圓角箭頭矩形的提示框
- iOS實(shí)現(xiàn)UITableView數(shù)據(jù)為空時(shí)的提示頁面
- iOS微信分享后關(guān)閉發(fā)送成功提示并返回應(yīng)用
- IOS開發(fā)實(shí)現(xiàn)手機(jī)震動(dòng)的提示實(shí)例代碼
- iOS自定義圓形進(jìn)度提示控件
相關(guān)文章
-
詳解iOS App中UIPickerView滾動(dòng)選擇欄的添加方法
UIPickerView組件在應(yīng)用中選擇地區(qū)等方面的運(yùn)用非常常見,能夠提供多列的選擇項(xiàng),下買呢我們就來詳解iOS App中UIPickerView滾動(dòng)選擇欄的添加方法 2016-05-05
-
Objective-C中類和方法的定義以及協(xié)議的使用
這篇文章主要介紹了Objective-C中類和方法的定義以及協(xié)議的使用,配合Mac下的Xcode IDE進(jìn)行講解,需要的朋友可以參考下 2016-01-01
-
實(shí)例講解設(shè)計(jì)模式中的命令模式在iOS App開發(fā)中的運(yùn)用
這篇文章主要介紹了設(shè)計(jì)模式中的命令模式在iOS App開發(fā)中的運(yùn)用,文中還講到了Cocoa框架下使用的例子,實(shí)例代碼為傳統(tǒng)的Objective-C,需要的朋友可以參考下 2016-03-03
-
iOS實(shí)現(xiàn)九宮格自動(dòng)生成視圖
這篇文章主要為大家詳細(xì)介紹了iOS實(shí)現(xiàn)九宮格自動(dòng)生成視圖的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下 2019-03-03
-
iOS tableView上拉刷新顯示下載進(jìn)度的問題及解決辦法
這篇文章主要介紹了 iOS tableView上拉刷新顯示下載進(jìn)度的問題及解決辦法,需要的朋友可以參考下 2017-03-03
-
詳解適配iOS10 的相關(guān)權(quán)限設(shè)置
在最新版本的iOS10系統(tǒng)中,如果你的項(xiàng)目中訪問了隱私數(shù)據(jù),比如:相機(jī)、相冊(cè)、錄音、定位、聯(lián)系人等等。涉及到權(quán)限問題,本篇文章主要介紹了適配iOS10 的相關(guān)權(quán)限設(shè)置,有興趣的可以了解一下。
2016-12-12
最新評(píng)論
本文實(shí)例為大家分享iOS自定義alertView提示框,先上圖,彈框的背景色,按鈕背景色,提示的消息的字體顏色都可以改變
利用單例實(shí)現(xiàn)豐富的自定義接口
// // PBAlertController.h // PBAlertDemo // // Created by 裴波波 on 16/4/20. // Copyright © 2016年 裴波波. All rights reserved. // #import <UIKit/UIKit.h> typedef void(^PBBlock)(); @interface PBAlertController : UIViewController /** 設(shè)置alertView背景色 */ @property (nonatomic, copy) UIColor *alertBackgroundColor; /** 設(shè)置確定按鈕背景色 */ @property (nonatomic, copy) UIColor *btnConfirmBackgroundColor; /** 設(shè)置取消按鈕背景色 */ @property (nonatomic, copy) UIColor *btnCancelBackgroundColor; /** 設(shè)置message字體顏色 */ @property (nonatomic, copy) UIColor *messageColor; /** 創(chuàng)建單例 */ +(instancetype)shareAlertController; /** 彈出alertView以及點(diǎn)擊確定回調(diào)的block */ -(void)alertViewControllerWithMessage:(NSString *)message andBlock:(PBBlock) block; @end
.m文件中初始化控件以及對(duì)alertView的控件的屬性進(jìn)行懶加載,確定初始的顏色.
// // PBAlertController.m // PBAlertDemo // // Created by 裴波波 on 16/4/20. // Copyright © 2016年 裴波波. All rights reserved. // #import "PBAlertController.h" /** 屏幕尺寸 */ #define kMainScreenBounds [UIScreen mainScreen].bounds @interface PBAlertController () /** 蒙版 */ @property (nonatomic, strong) UIView *coverView; /** 彈框 */ @property (nonatomic, strong) UIView *alertView; /** 點(diǎn)擊確定回調(diào)的block */ @property (nonatomic, copy) PBBlock block; @end @implementation PBAlertController - (void)viewDidLoad { [super viewDidLoad]; self.view.backgroundColor = [UIColor whiteColor]; } -(void)alertViewControllerWithMessage:(NSString *)message andBlock:(PBBlock) block{ self.block = block; //創(chuàng)建蒙版 UIView * coverView = [[UIView alloc] initWithFrame:kMainScreenBounds]; self.coverView = coverView; [self.view addSubview:coverView]; coverView.backgroundColor = [UIColor blackColor]; coverView.alpha = 0.7; //創(chuàng)建提示框view UIView * alertView = [[UIView alloc] init]; alertView.backgroundColor = self.alertBackgroundColor; //設(shè)置圓角半徑 alertView.layer.cornerRadius = 6.0; self.alertView = alertView; [self.view addSubview:alertView]; alertView.center = coverView.center; alertView.bounds = CGRectMake(0, 0, kMainScreenBounds.size.width * 0.75, kMainScreenBounds.size.width * 0.75 * 1.5/ 3); //創(chuàng)建操作提示 label UILabel * label = [[UILabel alloc] init]; [alertView addSubview:label]; label.text = @"操作提示"; label.font = [UIFont systemFontOfSize:19]; label.textAlignment = NSTextAlignmentCenter; CGFloat lblWidth = alertView.bounds.size.width; CGFloat lblHigth = 22; label.frame = CGRectMake(0, 0, lblWidth, lblHigth); //創(chuàng)建中間灰色分割線 UIView * separateLine = [[UIView alloc] init]; separateLine.backgroundColor = [UIColor grayColor]; [alertView addSubview:separateLine]; separateLine.frame = CGRectMake(0, lblHigth + 1, alertView.bounds.size.width, 1); //創(chuàng)建message label UILabel * lblMessage = [[UILabel alloc] init]; lblMessage.textColor = self.messageColor; [alertView addSubview:lblMessage]; lblMessage.text = message; lblMessage.textAlignment = NSTextAlignmentCenter; lblMessage.numberOfLines = 2; //最多顯示兩行Message CGFloat margin = 5; CGFloat msgX = margin; CGFloat msgY = lblHigth + 3; CGFloat msgW = alertView.bounds.size.width - 2 * margin; CGFloat msgH = 44; lblMessage.frame = CGRectMake(msgX, msgY, msgW, msgH); //創(chuàng)建確定 取消按鈕 CGFloat buttonWidth = (alertView.bounds.size.width - 4 * margin) * 0.5; CGFloat buttonHigth = 25; UIButton * btnCancel = [[UIButton alloc] init]; [alertView addSubview:btnCancel]; [btnCancel setTitleColor:[UIColor whiteColor] forState:UIControlStateNormal]; [btnCancel setTitle:@"取消" forState:UIControlStateNormal]; [btnCancel setBackgroundColor:self.btnCancelBackgroundColor]; btnCancel.frame = CGRectMake(margin, alertView.bounds.size.height - margin - buttonHigth, buttonWidth, buttonHigth); btnCancel.tag = 0; [btnCancel addTarget:self action:@selector(didClickBtnConfirm:) forControlEvents:UIControlEventTouchUpInside]; //確定按鈕 UIButton * btnConfirm = [[UIButton alloc] init]; btnConfirm.tag = 1; [alertView addSubview:btnConfirm]; [btnConfirm setTitleColor:[UIColor whiteColor] forState:UIControlStateNormal]; [btnConfirm setTitle:@"確定" forState:UIControlStateNormal]; [btnConfirm setBackgroundColor:self.btnConfirmBackgroundColor]; btnConfirm.frame = CGRectMake(alertView.bounds.size.width - margin - buttonWidth, alertView.bounds.size.height - margin - buttonHigth, buttonWidth, buttonHigth); [btnConfirm addTarget:self action:@selector(didClickBtnConfirm:) forControlEvents:UIControlEventTouchUpInside]; } /** 點(diǎn)擊確定 or 取消觸發(fā)事件 */ -(void)didClickBtnConfirm:(UIButton *)sender{ if (sender.tag == 0) { [self dismissViewControllerAnimated:YES completion:nil]; return; } self.block(); [self dismissViewControllerAnimated:YES completion:nil]; } - (void)didReceiveMemoryWarning { [super didReceiveMemoryWarning]; } static PBAlertController * instance = nil; +(instancetype)shareAlertController{ static dispatch_once_t onceToken; dispatch_once(&onceToken, ^{ instance = [[PBAlertController alloc] init]; }); return instance; } -(UIColor *)alertBackgroundColor{ if (_alertBackgroundColor == nil) { _alertBackgroundColor = [UIColor colorWithRed:249/255.0 green:249/255.0 blue:249/255.0 alpha:1]; } return _alertBackgroundColor; } /** 確定按鈕背景色 */ -(UIColor *)btnConfirmBackgroundColor{ if (_btnConfirmBackgroundColor == nil) { _btnConfirmBackgroundColor = [UIColor orangeColor]; } return _btnConfirmBackgroundColor; } /** 取消按鈕背景色 */ -(UIColor *)btnCancelBackgroundColor{ if (_btnCancelBackgroundColor == nil) { _btnCancelBackgroundColor = [UIColor blueColor]; } return _btnCancelBackgroundColor; } /** message字體顏色 */ -(UIColor *)messageColor{ if (_messageColor == nil) { _messageColor = [UIColor blackColor]; } return _messageColor; } @end
在需要調(diào)用的地方進(jìn)行調(diào)用
// // ViewController.m // PBAlertDemo // // Created by 裴波波 on 16/4/20. // Copyright © 2016年 裴波波. All rights reserved. // #import "ViewController.h" #import "PBAlertController.h" @interface ViewController () @end @implementation ViewController //點(diǎn)擊按鈕彈出提示框 - (IBAction)clickShowAlertBtn:(id)sender { PBAlertController * alertVc = [PBAlertController shareAlertController]; alertVc.messageColor = [UIColor redColor]; [alertVc alertViewControllerWithMessage:@"這是一message沙哈" andBlock:^{ NSLog(@"點(diǎn)擊確定后執(zhí)行的方法"); }]; alertVc.modalTransitionStyle = UIModalTransitionStyleCrossDissolve; [self presentModalViewController:alertVc animated:YES]; } @end
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家學(xué)習(xí)iOS程序設(shè)計(jì)有所幫助。
- iOS9提示框的正確使用方式
- iOS移動(dòng)端(H5)alert/confirm提示信息去除網(wǎng)址(URL)
- iOS自定義提示彈出框?qū)崿F(xiàn)類似UIAlertView的效果
- iOS自定義推送消息提示框
- Android仿IOS自定義AlertDialog提示框
- iOS實(shí)現(xiàn)圓角箭頭矩形的提示框
- iOS實(shí)現(xiàn)UITableView數(shù)據(jù)為空時(shí)的提示頁面
- iOS微信分享后關(guān)閉發(fā)送成功提示并返回應(yīng)用
- IOS開發(fā)實(shí)現(xiàn)手機(jī)震動(dòng)的提示實(shí)例代碼
- iOS自定義圓形進(jìn)度提示控件
相關(guān)文章
詳解iOS App中UIPickerView滾動(dòng)選擇欄的添加方法
UIPickerView組件在應(yīng)用中選擇地區(qū)等方面的運(yùn)用非常常見,能夠提供多列的選擇項(xiàng),下買呢我們就來詳解iOS App中UIPickerView滾動(dòng)選擇欄的添加方法2016-05-05Objective-C中類和方法的定義以及協(xié)議的使用
這篇文章主要介紹了Objective-C中類和方法的定義以及協(xié)議的使用,配合Mac下的Xcode IDE進(jìn)行講解,需要的朋友可以參考下2016-01-01實(shí)例講解設(shè)計(jì)模式中的命令模式在iOS App開發(fā)中的運(yùn)用
這篇文章主要介紹了設(shè)計(jì)模式中的命令模式在iOS App開發(fā)中的運(yùn)用,文中還講到了Cocoa框架下使用的例子,實(shí)例代碼為傳統(tǒng)的Objective-C,需要的朋友可以參考下2016-03-03iOS實(shí)現(xiàn)九宮格自動(dòng)生成視圖
這篇文章主要為大家詳細(xì)介紹了iOS實(shí)現(xiàn)九宮格自動(dòng)生成視圖的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-03-03iOS tableView上拉刷新顯示下載進(jìn)度的問題及解決辦法
這篇文章主要介紹了 iOS tableView上拉刷新顯示下載進(jìn)度的問題及解決辦法,需要的朋友可以參考下2017-03-03詳解適配iOS10 的相關(guān)權(quán)限設(shè)置
在最新版本的iOS10系統(tǒng)中,如果你的項(xiàng)目中訪問了隱私數(shù)據(jù),比如:相機(jī)、相冊(cè)、錄音、定位、聯(lián)系人等等。涉及到權(quán)限問題,本篇文章主要介紹了適配iOS10 的相關(guān)權(quán)限設(shè)置,有興趣的可以了解一下。2016-12-12