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

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

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

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

[cpp] view plaincopy
  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

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

[cpp] view plaincopy
  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的形式来操作的,这样写起代码来更直观也更高效。

转载于:https://www.cnblogs.com/wangyang1213/p/5300844.html

iOS MBProgressHUD 之带底板的加载提示相关推荐

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

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

  2. iOS和tvOS游戏按需加载资源简介

    2019独角兽企业重金招聘Python工程师标准>>> 戴维营教育翻译:感谢Davis Allie的An Introduction to On-Demand Resources on ...

  3. IOS欢迎界面Launch Screen动态加载广告

    IOS欢迎界面Launch Screen动态加载广告,ioslaunch 当我们打开一款应用程序的时候,首先映入眼帘的往往并不是程序的主界面,而是经过精心设计的欢迎界面,这个界面通常会停留几秒钟,然后 ...

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

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

  5. 10.1登录成功提示、加载提示

    制作登录成功提示 我们可以去vant找到 接下来的操作就是和之前一样 先去src/utils/vant.js导入 因为这个轻提示,整个项目都需要它,所以我们用全局引入的方式 如果想改成别的样式 加载提 ...

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

    这里介绍一下网友开源的MBProgressHUD类,实现等待框, 一.网上下载  MBProgessHUD 类文件,直接导入到工程即可 二.示例分析 在我的工程中示例如下: 1)在ShowImageV ...

  7. 【iOS】通过NSURLProtocol提高Web加载速度

    一.项目需求 项目中有个海报功能,是用UIWebView加载h5网页的形式.因为海报的使用率比较高,如果网页加载得比较慢会严重影响用户体验,因此我们想了一个方法,在用户启动APP后,如果连接了Wi-F ...

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

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

  9. 微信小程序——焦点图 可预览查看大图缩放(多张可左右滑动) 带页码 loading 加载中 / https不显示图

    微信小程序焦点图,可以滑动预览大图缩放 微信小程序自带焦点图swiper ,但是没有页码,只有小圆点,所以要自己写 (在查看大图时遇到一个问题,安卓上查看大图部分图不显示,经排查,发现不显示的图片地址 ...

最新文章

  1. nodejs学习资料
  2. VS2010打开项目提示未能正确加载解决方案中一个或多个项目
  3. php阿里的同步工具canal,基于阿里的Canal实现数据同步
  4. 家庭装修里最大的问题
  5. Spring boot 打包jar 将配置文件分离
  6. Linux安装好php后找不到php.ini
  7. php入口函数,php 常用的系统函数
  8. 主站系统服务器选择,配电网自动化主站系统的结构_功能及操作系统的选择.doc...
  9. c语言手游常用代码,c语言源代码【操作流程】
  10. linux 双网卡 debian,Debian 双网卡bond
  11. plsql变量参数化_谁说建模一定要会画图?参数化设计让你事半功倍!
  12. 【精心挑选】推荐几款非常棒的 jQuery 全景图片展示插件
  13. 安防在智能家居中扮演什么角色?
  14. 关于Universal-Image-Loader加载同一张图只成功一张的问题
  15. 电子与智能化工程专业承包资质标准
  16. 《生物化学与分子生物学》----酶促反应动力学----听课笔记(九)
  17. 【学习记录】图片行列切割与子图行列拼接之中央裁剪法
  18. 基于qiankun搭建ng-alain15微前端项目入门实践
  19. 超级右键 iRightMouse --Mac强大的右键菜单设置工具
  20. AD各种布线方法总结

热门文章

  1. 腾讯云对象存储 python_python 云存储
  2. 如何查看电脑显卡配置_组装电脑:电脑配置显卡推荐
  3. 西北大学计算机排行,世界排名领先,西北大学到底有多厉害?
  4. 敏捷估计与规划pdf
  5. SAP RFC 获取BDC 消息文本的实现
  6. GDB调试程序(二)
  7. 【原】UIView实现点击着重效果的解决方案
  8. 我理解的invoke和begininvoke
  9. 【转载】快速、可伸缩和流式的AJAX代理--跨域持续内容分发
  10. oracle dw报告,讲解Oracle数据库的全文索引设置步骤