文章来自:http://blog.csdn.net/ryantang03/article/details/7877120

MBProgressHUD是一个开源项目,实现了很多种样式的提示框,使用上简单、方便,并且可以对显示的内容进行自定义,功能很强大,很多项目中都有使用到。到GitHub上可以下载到项目源码https://github.com/jdg/MBProgressHUD,下载下来后直接把MBProgressHUD.h和MBProgressHUD.m拖入工程中就行,别忘了选择拷贝到工程。完了在需要使用的地方导入头文件就可以开始使用了。首先看下工程截图:

接下来是整个Demo的完整界面,这里我只选择出了几个常用的对话框,其他样式的在源码提供的Demo里可以找到,要用的话直接参考就可以。

接下来直接上代码了,头文件部分:

  1. #import <UIKit/UIKit.h>
  2. #import "MBProgressHUD.h"
  3. @interface ViewController : UIViewController
  4. {
  5. //HUD(Head-Up Display,意思是抬头显示的意思)
  6. MBProgressHUD *HUD;
  7. }
  8. - (IBAction)showTextDialog:(id)sender;
  9. - (IBAction)showProgressDialog:(id)sender;
  10. - (IBAction)showProgressDialog2:(id)sender;
  11. - (IBAction)showCustomDialog:(id)sender;
  12. - (IBAction)showAllTextDialog:(id)sender;
  13. @end

实现文件(按钮实现部分):

  1. - (IBAction)showTextDialog:(id)sender {
  2. //初始化进度框,置于当前的View当中
  3. HUD = [[MBProgressHUD alloc] initWithView:self.view];
  4. [self.view addSubview:HUD];
  5. //如果设置此属性则当前的view置于后台
  6. HUD.dimBackground = YES;
  7. //设置对话框文字
  8. HUD.labelText = @"请稍等";
  9. //显示对话框
  10. [HUD showAnimated:YES whileExecutingBlock:^{
  11. //对话框显示时需要执行的操作
  12. sleep(3);
  13. } completionBlock:^{
  14. //操作执行完后取消对话框
  15. [HUD removeFromSuperview];
  16. [HUD release];
  17. HUD = nil;
  18. }];
  19. }
  20. - (IBAction)showProgressDialog:(id)sender {
  21. HUD = [[MBProgressHUD alloc] initWithView:self.view];
  22. [self.view addSubview:HUD];
  23. HUD.labelText = @"正在加载";
  24. //设置模式为进度框形的
  25. HUD.mode = MBProgressHUDModeDeterminate;
  26. [HUD showAnimated:YES whileExecutingBlock:^{
  27. float progress = 0.0f;
  28. while (progress < 1.0f) {
  29. progress += 0.01f;
  30. HUD.progress = progress;
  31. usleep(50000);
  32. }
  33. } completionBlock:^{
  34. [HUD removeFromSuperview];
  35. [HUD release];
  36. HUD = nil;
  37. }];
  38. }
  39. - (IBAction)showProgressDialog2:(id)sender {
  40. HUD = [[MBProgressHUD alloc] initWithView:self.view];
  41. [self.view addSubview:HUD];
  42. HUD.labelText = @"正在加载";
  43. HUD.mode = MBProgressHUDModeAnnularDeterminate;
  44. [HUD showAnimated:YES whileExecutingBlock:^{
  45. float progress = 0.0f;
  46. while (progress < 1.0f) {
  47. progress += 0.01f;
  48. HUD.progress = progress;
  49. usleep(50000);
  50. }
  51. } completionBlock:^{
  52. [HUD removeFromSuperview];
  53. [HUD release];
  54. HUD = nil;
  55. }];
  56. }
  57. - (IBAction)showCustomDialog:(id)sender {
  58. HUD = [[MBProgressHUD alloc] initWithView:self.view];
  59. [self.view addSubview:HUD];
  60. HUD.labelText = @"操作成功";
  61. HUD.mode = MBProgressHUDModeCustomView;
  62. HUD.customView = [[[UIImageView alloc] initWithImage:[UIImage imageNamed:@"Checkmark"]] autorelease];
  63. [HUD showAnimated:YES whileExecutingBlock:^{
  64. sleep(2);
  65. } completionBlock:^{
  66. [HUD removeFromSuperview];
  67. [HUD release];
  68. HUD = nil;
  69. }];
  70. }
  71. - (IBAction)showAllTextDialog:(id)sender {
  72. HUD = [[MBProgressHUD alloc] initWithView:self.view];
  73. [self.view addSubview:HUD];
  74. HUD.labelText = @"操作成功";
  75. HUD.mode = MBProgressHUDModeText;
  76. //指定距离中心点的X轴和Y轴的偏移量,如果不指定则在屏幕中间显示
  77. //    HUD.yOffset = 150.0f;
  78. //    HUD.xOffset = 100.0f;
  79. [HUD showAnimated:YES whileExecutingBlock:^{
  80. sleep(2);
  81. } completionBlock:^{
  82. [HUD removeFromSuperview];
  83. [HUD release];
  84. HUD = nil;
  85. }];
  86. }

依次实现的效果如下:

               

               

下面这个效果就类似Android中的Toast:

以上就简单介绍了MBProgressHUD的使用,这里都是采用block的形式来操作的,这样写起代码来更直观也更高效。

iOS MBProgressHUD 之带底板的加载提示的更多相关文章

  1. [置顶] iOS学习笔记47——图片异步加载之EGOImageLoading

    上次在<iOS学习笔记46——图片异步加载之SDWebImage>中介绍过一个开源的图片异步加载库,今天来介绍另外一个功能类似的EGOImageLoading,看名字知道,之前的一篇学习笔 ...

  2. ios网络学习------4 UIWebView的加载本地数据的三种方式

    ios网络学习------4 UIWebView的加载本地数据的三种方式 分类: IOS2014-06-27 12:56 959人阅读 评论(0) 收藏 举报 UIWebView是IOS内置的浏览器, ...

  3. 用UBOOT自带loadb命令加载应用程序到SDRAM中运行的方法

    S3C44B0开发板中,用UBOOT自带loadb命令加载应用程序到SDRAM中运行的方法    1.开发板说明:  开发板上已有移植好的UBOOT运行.   2.交叉编译工具链为arm-linu-g ...

  4. Ladda – 把加载提示效果集成到按钮中,提升用户体验

    Ladda 是一组集成了加载提示的按钮,以弥合行动和反馈之间的时间间隔,提供更好的功能使用体验.主要用于在用户点击提交之后,向用户提供即时的反馈,让他们知道浏览器正在处用户提交的任务. 您可能感兴趣的 ...

  5. jQuery Ajax封装(附带加载提示和请求结果提示模版)

    1.创建HTML文件(demo) <!doctype html> <html lang="en"> <head> <meta charse ...

  6. IOS开发UI篇之──自定义加载等待框(MBProgressHUD)

    本文转载至 http://blog.csdn.net/xunyn/article/details/8064984   原文地址http://www.189works.com/article-89289 ...

  7. [IOS]UIWebView 请求网络页面或者加载本地资源页面

    UIWebView是一个能够显示网页的IOS视图控件,我们可以用它来访问一个网站.下面是具体的实例: 操作步骤: 1.首先在xib文件中拖放一个UIWebView控件到view中 2.将下载的页面以及 ...

  8. iOS开发之控制器创建与加载(生命周期)

    1.如何创建一个控制器 控制器常见的创建方式有以下几种: (1)通过storyboard创建 (2)直接创建 MJViewController *mj = [[MJViewController all ...

  9. IOS空数据页面,网络加载失败以及重新登陆View的封装(不需要继承)

    一.问题 对于B2C和B2B项目的开发者,可能会有一个订单列表为空,或者其他收藏页面为空,用户token失效,判断用户要重新登陆,以及后台服务错误等提示.本篇课文,看完大约10分钟. 原本自己不想写空 ...

随机推荐

  1. :before和:after的内幕以及伪类

    pseudo-classes vs pseudo-elements http://m.blog.csdn.net/blog/zhuizhuziwo/7897837

  2. Oracle SQL篇(一)null值之初体验

           从我第一次正式的写sql语句到现在,已经超过10年的时间了.我写报表,做统计分析和财务对账,我一点点的接触oracle数据库,并尝试深入了解.这条路,一走就是10年,从充满热情,到开始厌 ...

  3. 查看Xcode所使用Swift的版本

    查看Swift版本 $ xcrun swift -version 查看Xcode位置 $ xcrun --find swift 参考链接:http://stackoverflow.com/questi ...

  4. 射频识别技术漫谈(15)——Mifare1的安全性及7字节序列号M1卡

    Mifare1的安全性主要指卡中数据的安全性,要求卡中的数据不能被非法修改或窃听.数据的安全性主要使用加密技术来保证,加密技术有两个关键因素:加密算法和密钥.现代加密技术的一大特点是加密算法公开,如果 ...

  5. 利用bind搭建dns

    下载bind,我下载的是bind-9.3.1rc1.tar.gz 我下载的文件放在/root目录下 进入目录解压缩 [root@linux root]#tar xfz bind-9.3.1rc1.ta ...

  6. JDBC初步(一)

    import java.sql.*; public class TestJDBC { // orcl为oracle数据库中的数据库名,localhost表示连接本机的oracle数据库 // 1521 ...

  7. C# Code Snip

    1.Tryf + TAB+TAB try { } finally { } 2.Prop+Tab+Tab public int MyProperty { get; set; } 3. #region + ...

  8. ajax的简单操作

    项目需要,简单研究了下ajax 需要在html中引入js文件 编写js函数 function testAjax() { $.ajax({ type: 'get', //请求方式 get/post ur ...

  9. 无法编辑的word解密

    打开文档后,将其另存为XML文件,然后用UltraEdit(或者EditPlus,下载华军里搜索一下就行了)这个编辑软件打开刚刚存储的 XLM文件,查找<w:documentProtection ...

  10. 【监控】使用probe对tomcat服务进行监控

    1.运行环境(博主本地) JDK:jdk1.6 Tomcat:tomcat7 OS:Windows10 2.下载 点击下载 3.安装运行 1.解压,将probe文件夹复制放进tomcat里面的weba ...