iOS 第三方-MBProgressHUD

使用

创建 MBProgressHUD的分类

.h中

#import <MBProgressHUD/MBProgressHUD.h>

@interface MBProgressHUD (PD)


+ (void)showSuccess:(NSString *)success;
+ (void)showSuccess:(NSString *)success toView:(UIView *)view;

+ (void)showError:(NSString *)error;
+ (void)showError:(NSString *)error toView:(UIView *)view;

+ (MBProgressHUD *)showMessage:(NSString *)message;
+ (MBProgressHUD *)showMessage:(NSString *)message toView:(UIView *)view;

+ (void)hideHUD;
+ (void)hideHUDForView:(UIView *)view;



@end

.m中


#import "MBProgressHUD+PD.h"

@implementation MBProgressHUD (PD)


/**
 *  =======显示信息
 *  @param text 信息内容
 *  @param icon 图标
 *  @param view 显示的视图
 */
+ (void)show:(NSString *)text icon:(NSString *)icon view:(UIView *)view
{
    if (view == nil)
        view = [[UIApplication sharedApplication].windows lastObject];
    // 快速显示一个提示信息
    MBProgressHUD *hud = [MBProgressHUD showHUDAddedTo:view animated:YES];
    hud.label.text = text;

    hud.label.textColor = Color333333;
    //hud.bezelView.style = MBProgressHUDBackgroundStyleSolidCo;
    hud.label.font = [UIFont systemFontOfSize:17.0];
    hud.userInteractionEnabled= NO;
    
    hud.customView = [[UIImageView alloc] initWithImage:icon];  // 设置图片
    hud.bezelView.backgroundColor = mainGrayColor;    //背景颜色
    // 设置图片
    hud.customView = [[UIImageView alloc] initWithImage:[UIImage imageNamed:[NSString stringWithFormat:@"MBProgressHUD.bundle/%@", icon]]];
    // 再设置模式
    hud.mode = MBProgressHUDModeCustomView;
    
    // 隐藏时候从父控件中移除
    hud.removeFromSuperViewOnHide = YES;
    
    // 1秒之后再消失
    [hud hideAnimated:YES afterDelay:1.5];
}

/**
 *  =======显示 提示信息
 *  @param success 信息内容
 */
+ (void)showSuccess:(NSString *)success
{
    [self showSuccess:success toView:nil];
}

/**
 *  =======显示
 *  @param success 信息内容
 */
+ (void)showSuccess:(NSString *)success toView:(UIView *)view
{
    [self show:success icon:@"success.png" view:view];
}

/**
 *  =======显示错误信息
 */
+ (void)showError:(NSString *)error
{
    [self showError:error toView:nil];
}

+ (void)showError:(NSString *)error toView:(UIView *)view{
    [self show:error icon:@"error.png" view:view];
}
/**
 *  显示提示 + 菊花
 *  @param message 信息内容
 *  @return 直接返回一个MBProgressHUD, 需要手动关闭(  ?
 */
+ (MBProgressHUD *)showMessage:(NSString *)message
{
    return [self showMessage:message toView:nil];
}

/**
 *  显示一些信息
 *  @param message 信息内容
 *  @param view    需要显示信息的视图
 *  @return 直接返回一个MBProgressHUD,需要手动关闭
 */
+ (MBProgressHUD *)showMessage:(NSString *)message toView:(UIView *)view {
    if (view == nil) view = [[UIApplication sharedApplication].windows lastObject];
    // 快速显示一个提示信息
    MBProgressHUD *hud = [MBProgressHUD showHUDAddedTo:view animated:YES];
    hud.label.text = message;
    // 隐藏时候从父控件中移除
    hud.removeFromSuperViewOnHide = YES;
    // YES代表需要蒙版效果
    hud.dimBackground = YES;
    
    return hud;
}

/**
 *  手动关闭MBProgressHUD
 */
+ (void)hideHUD
{
    [self hideHUDForView:nil];
}
/**
 *  @param view    显示MBProgressHUD的视图
 */
+ (void)hideHUDForView:(UIView *)view
{
    if (view == nil)
        view = [[UIApplication sharedApplication].windows lastObject];
    
    [self hideHUDForView:view animated:YES];
}

@end

样式选择

用法一:文字提示+菊花,延迟s后消失,再出现文字提示

 
 [MBProgressHUD showMessage:@"正在加载..."];
 
 int64_t delayInSeconds = 2.0;      // 延迟的时间
 
 dispatch_time_t popTime = dispatch_time(DISPATCH_TIME_NOW, delayInSeconds * NSEC_PER_SEC);
 dispatch_after(popTime, dispatch_get_main_queue(), ^(void){
 
 [MBProgressHUD hideHUD];
 [MBProgressHUD showError:@"加载失败,请检查网络" toView:nil];
 });
 

用法二:只提示文字,延迟s后消失

    [MBProgressHUD showError:@"登录失败" toView:nil];  

    //[MBProgressHUD showSuccess:@"成功登录"];   

轻量级SVProgressHUD

新建分类
添加分类方法

+(void)showYESmessage:(NSString *)mesg;
+(void)showNOmessage:(NSString *)mesg;
+(void)showStatesMsge:(NSString *)mesg;
+(void)showStatesMsgeWithTime:(NSString *)mesg;

实现


+(void)showYESmessage:(NSString *)mesg{
    
    [SVProgressHUD showSuccessWithStatus:mesg];
    [SVProgressHUD setForegroundColor:[UIColor blackColor]];
    [SVProgressHUD dismissWithDelay:1];      //mesg.length/3];
    
}

+(void)showNOmessage:(NSString *)mesg{
    
    //[SVProgressHUD showErrorWithStatus:mesg];  //  X + 提示
    
    [SVProgressHUD showInfoWithStatus:mesg];     // ! + 提示
    [SVProgressHUD setForegroundColor:[UIColor blackColor]];
    //[SVProgressHUD showImage:nil status:mesg];
    
    [SVProgressHUD dismissWithDelay:1];     //mesg.length/3];
}

+(void)showStatesMsge:(NSString *)mesg{
    [SVProgressHUD showWithStatus:mesg];    //转圈 + 提示   ----! 需手动隐藏
    [SVProgressHUD setForegroundColor:mainRedColor];
    
    //[SVProgressHUD dismissWithDelay:1];
}

+(void)showStatesMsgeWithTime:(NSString *)mesg{
    
    [SVProgressHUD showWithStatus:mesg];//???
    
    [SVProgressHUD setForegroundColor:mainRedColor];
    
    [SVProgressHUD dismissWithDelay:1.5];
}

自定义SVProgressHUD

// 设置最大、小显示时间
 [SVProgressHUD setMaximumDismissTimeInterval:10.];
 [SVProgressHUD setMaximumDismissTimeInterval:1.];

//设置样式:背景黑色、字体白色
   [SVProgressHUD setDefaultStyle:SVProgressHUDStyleDark];
//设置蒙版暗淡,不允许触屏
    [SVProgressHUD setDefaultMaskType:SVProgressHUDMaskTypeBlack];
//设置蒙版颜色及透明度
    [SVProgressHUD setBackgroundLayerColor:[UIColor colorWithRed:0.3 green:0.4 blue:0.5 alpha:0.2]];
// 位置 偏移
    [SVProgressHUD setOffsetFromCenter:UIOffsetMake(0, SCREEN_H/3)];

// 环线圆角(默认18pt)
    [SVProgressHUD setRingRadius:20];
// 环线厚度(默认2pt)
    [SVProgressHUD setRingThickness:2];
// 设置HUD的圆角
    [SVProgressHUD setCornerRadius:20];
// 设置字体
    [SVProgressHUD setFont: [UIFont preferredFontForTextStyle:UIFontTextStyleCallout]];
//设置HUD前景字体、背景颜色(SVProgressHUDStyleCustom的模式下有效)
    [SVProgressHUD setForegroundColor:[UIColor yellowColor]];
    [SVProgressHUD setBackgroundColor:[UIColor blackColor]];
// 设置HUD的图标icon
    [SVProgressHUD setInfoImage:[UIImage imageNamed:@"ii"]];
    [SVProgressHUD showInfoWithStatus:@"密码错误"];     
...
    [SVProgressHUD setSuccessImage:[UIImage imageNamed:@"ii"]];
    [SVProgressHUD showSuccessWithStatus:@"登录成功"];

// 设置原生动画效果
    [SVProgressHUD setDefaultAnimationType:SVProgressHUDAnimationTypeNative];
// 设置弹出动画
    [SVProgressHUD setFadeInAnimationDuration:0.35]; //放大出现
    [SVProgressHUD setFadeOutAnimationDuration:1.5]; // 缩小消失


相关资料
https://blog.csdn.net/wujakf/article/details/70882827
https://www.jianshu.com/p/a08d4597cf24

交互式提示

    UIAlertView *aler = [[UIAlertView alloc] initWithTitle:@"未检测到支付宝!" message:@"提示信息" 
    delegate:self cancelButtonTitle:@"确定" otherButtonTitles: nil];
    [aler show];

https://www.cnblogs.com/wujy/p/5572762.html

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,463评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,868评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,213评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,666评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,759评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,725评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,716评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,484评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,928评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,233评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,393评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,073评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,718评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,308评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,538评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,338评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,260评论 2 352

推荐阅读更多精彩内容