文章来自: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. c++之构造函数学习

    #include<stdio.h> class Test {      private:      int i;      int j;      int k;     public :  ...

  2. BZOJ 1316: 树上的询问( 点分治 + 平衡树 )

    直接点分治, 用平衡树(set就行了...)维护. -------------------------------------------------------------------------- ...

  3. 设计模式的PHP实现示例(转)

    symfony2 很多设计模式思想,下面的资料会有点帮助:http://www.open-open.com/lib/view/open1414996676559.html 阅读目录 Creationa ...

  4. python re(正则模块)

    参考文档:http://blog.csdn.net/wusuopubupt/article/details/29379367 ipython环境中,输入"?re",官方解释如下: ...

  5. 怎么给没链接的flash加超链接

    最近开始准备设计一个广告条,本想用阿里妈妈的的banner marker来设计,却遗憾的发现,banner marker已经实行收费模式了. 我不得不启用另一款在线banner生成工具,百度旗下的&q ...

  6. 求1+2+...+n

    题目:求1+2+…+n,要求不能使用乘除法.for.while.if.else.switch.case等关键字以及条件判断语句(A?B:C). 程序很简单,就看想到想不到了.悲剧,我属于后者... 算 ...

  7. php 前台数据显示

    <pre name="code" class="html"> public function show(){ echo "访问了index ...

  8. C++模板:ST算法

    //初始化 void init_rmq(int n){ for(int i=0;i<n;i++)d[i][0]=a[i]; for(int j=1;(1<<j)<=n;j++) ...

  9. 数据结构与算法分析 3.4&3.5 — 链表的交与并算法

    代码: #include <list> template<typename ElementType> list<ElementType> Intersect(con ...

  10. USB设备在连接PC时的reset从何而来?

    近期在做烧写工具的优化工作,有一些关于USB的内容须要总结一下当中包含设备的初始化过程和枚举过程. 在枚举的过程中,设备会一直等PC端的状态,当等到reset命令时会对设备进行又一次枚举.可是这个re ...