提示框框架KVNProgress介绍
gitHub上面有很多显示加载进度的框架,这里我们介绍一下KVNProgress框架,KVNProgress是一个可以完全定制的HUD(指示器),你可以设置加载进度的画面是否全屏,可以自己修改进度显示的风格,同时这个框架也支持在ipad上面使用,效果如下:

一、导入KVNProgress框架
- 在github上面下载框架,并将相关的文件夹引入到项目中

- 在工程中添加所需头文件
- #import "KVNProgress.h"
二、关键属性及方法介绍
- @property (nonatomic, getter = isFullScreen) BOOL fullScreen;//设置是否全屏显示
- + (void)show; //显示提示框
- + (void)showWithStatus:(NSString *)status; // 在图形的下方添加描述状态的文字
- + (void)showProgress:(CGFloat)progress; // 用0-1表示进度加载的%0-%100
- + (void)showProgress:(CGFloat)progress status:(NSString*)status; // 在显示进度的图形下面自定义一段文字
- + (void)showSuccessWithStatus:(NSString *)status;//显示加载成功
- + (void)showErrorWithStatus:(NSString *)status;//显示加载失败
- + (void)dismiss;//移除提示框
- + (void)updateStatus:(NSString*)status; //根据进度更新图形下方的文字
- + (void)updateProgress:(CGFloat)progress animated:(BOOL)animated; //更新此时加载的进度
- + (void)setConfiguration:(KVNProgressConfiguration *)newConfiguration;//设置进度视图的样式
- + (instancetype)defaultConfiguration;//默认图形样式
三、使用场景1:基本使用

- 添加相关属性
- #import "ViewController.h"
- #import "KVNProgress.h"
- @interface ViewController ()
- //框架相关属性
- @property (nonatomic) KVNProgressConfiguration *basicConfiguration;//显示进度的图形为基本样式
- @property (nonatomic, strong) UIButton *basicBtn;//显示基本样式的按钮
- @end
- 使用懒加载方式初始化用到的控件
- - (UIButton *)basicBtn{
- if (!_basicBtn) {
- _basicBtn = [[UIButton alloc] initWithFrame:CGRectMake(119, 136, 137, 30)];
- [_basicBtn setTitle:@"basic" forState:UIControlStateNormal];
- _basicBtn.backgroundColor = [UIColor grayColor];
- [_basicBtn addTarget:self action:@selector(basic) forControlEvents:UIControlEventTouchUpInside];
- [self.view addSubview:_basicBtn];
- }
- return _basicBtn;
- }
- - (void)viewDidLoad {
- [super viewDidLoad];
- [self myWebView];
- [self basicBtn];
- //设置加载进度图形的样式为基本样式
- [KVNProgress setConfiguration:self.basicConfiguration];
- //设置基本样式为默认的样式
- self.basicConfiguration = [KVNProgressConfiguration defaultConfiguration];
- }
- 完成KVNProgress的相关设置
- - (void) basic{
- [KVNProgress show];
- //延时1秒以后移除提示框
- dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(1.0f * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
- self.basicConfiguration.tapBlock = nil;
- [KVNProgress dismiss];
- });
- }
四、使用场景2:加载成功与加载错误
当我们登陆成功或者登陆失败之后,经常出现一个相关的提示框,如下图:


- 添加相关属性
- @property (nonatomic, strong) UIButton *successBtn;
- @property (nonatomic, strong) UIButton *errorBtn;
- 使用懒加载方式初始化用到的控件
- - (UIButton *)successBtn{
- if (!_successBtn) {
- _successBtn = [[UIButton alloc] initWithFrame:CGRectMake(119, 241, 137, 30)];
- [_successBtn setTitle:@"success" forState:UIControlStateNormal];
- _successBtn.backgroundColor = [UIColor grayColor];
- [_successBtn addTarget:self action:@selector(success) forControlEvents:UIControlEventTouchUpInside];
- [self.view addSubview:_successBtn];
- }
- return _successBtn;
- }
- - (UIButton *)errorBtn{
- if (!_errorBtn) {
- _errorBtn = [[UIButton alloc] initWithFrame:CGRectMake(119, 341, 137, 30)];
- [_errorBtn setTitle:@"error" forState:UIControlStateNormal];
- _errorBtn.backgroundColor = [UIColor grayColor];
- [_errorBtn addTarget:self action:@selector(error) forControlEvents:UIControlEventTouchUpInside];
- [self.view addSubview:_errorBtn];
- }
- return _errorBtn;
- }
- 完成KVNProgress的相关设置
- - (void) success{
- [KVNProgress show];
- dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(4.0f * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
- self.basicConfiguration.tapBlock = nil;
- //提示加载成功
- [KVNProgress showSuccessWithStatus:@"Success"];
- });
- }
- - (void) error{
- [KVNProgress show];
- dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(4.0f * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
- self.basicConfiguration.tapBlock = nil;
- //提示加载失败
- [KVNProgress showErrorWithStatus:@"Error"];
- });
- }
五、使用场景3:复杂使用
在我们加载网页的时候,需要根据它的加载情况来改变提示框中的图形,如下图:


- 添加相关属性及其代理协议
- @interface ViewController ()
- @property (nonatomic, strong) UIButton *complexBtn;
- @property (nonatomic, strong) UIWebView *myWebView;
- @end
- 使用懒加载方式初始化用到的控件
- - (UIButton *)complexBtn{
- if (!_complexBtn) {
- _complexBtn = [[UIButton alloc] initWithFrame:CGRectMake(119, 441, 137, 30)];
- [_complexBtn setTitle:@"complex" forState:UIControlStateNormal];
- _complexBtn.backgroundColor = [UIColor grayColor];
- [_complexBtn addTarget:self action:@selector(complex) forControlEvents:UIControlEventTouchUpInside];
- [self.view addSubview:_complexBtn];
- }
- return _complexBtn;
- }
- - (UIWebView *)myWebView{
- if (!_myWebView) {
- _myWebView = [[UIWebView alloc] initWithFrame:self.view.bounds];
- NSURL *url = [NSURL URLWithString:@"http://www.hcios.com"];
- NSURLRequest *myRequest = [NSURLRequest requestWithURL:url];
- [_myWebView loadRequest:myRequest];
- _myWebView.delegate = self;
- [self.view addSubview:_myWebView];
- }
- return _myWebView;
- }
- 完成KVNProgress的相关设置
- - (void) complex{
- //创建一个视图控制器用来显示webView
- UIViewController *myController = [[UIViewController alloc] init];
- //创建一个返回原来控制器的按钮
- UIButton *backBtn = [[UIButton alloc] initWithFrame:CGRectMake(10,10, 50, 50)];
- [backBtn setTitle:@"返回" forState:UIControlStateNormal];
- backBtn.backgroundColor = [UIColor redColor];
- [backBtn addTarget:self action:@selector(back) forControlEvents:UIControlEventTouchUpInside];
- [self.myWebView addSubview:backBtn];
- [myController.view addSubview: self.myWebView];
- [self presentViewController:myController animated:YES completion:nil];
- }
- - (void) back{
- [self dismissViewControllerAnimated:YES completion:nil];
- }
- //在webView开始加载时候调用的函数里面设置相应的加载动画
- - (void)webViewDidStartLoad:(UIWebView *)webView{
- //开始加载,文字可以自定义
- [KVNProgress showProgress:0.0f
- status:@"加载中"];
- //延时0.2秒以后更新进度条显示加载到%50的位置
- dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.2 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
- [KVNProgress updateProgress:0.5f
- animated:YES];
- });
- //延时0.5秒以后修改图形下方的文字
- dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.5 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
- [KVNProgress updateStatus:@"请耐心等待"];
- });
- }
- //当webView加载完毕以后调用
- - (void)webViewDidFinishLoad:(UIWebView *)webView{
- //加载进度条显示加载完毕
- [KVNProgress updateProgress:1.0f
- animated:YES];
- //延时0.1秒以后隐藏加载进度的图形
- dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.1 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
- [KVNProgress dismiss];
- });
- }
六、KVNProgress和示例代码下载
提示框框架KVNProgress介绍的更多相关文章
- UWP中的消息提示框(二)
在UWP中的消息提示框(一)中介绍了一些常见的需要用户主动去干涉的一些消息提示框,接下来打算聊聊不需要用户主动去干涉的一些消息提示框.效果就是像双击退出的那种提示框. 先说说比较简单的吧,通过系统To ...
- 第三方框架MBProgressHUD-----实现各种提示框
程序运行显示如下 : 点击按钮实现对应的提示框: 这里只截取了其中一张图,有兴趣的可以自己运行程序,查看其他的几种提示框哟!!! 第三方框架MBProgressHUD的下载地址:https://git ...
- 基于Metronic的Bootstrap开发框架经验总结(6)--对话框及提示框的处理和优化
在各种Web开发过程中,对话框和提示框的处理是很常见的一种界面处理技术,用得好,可以给用户很好的页面体验,Bootstrap开发也一样,我们往往在页面新增.编辑.查看详细等界面使用弹出对话框层的方式进 ...
- PHP弹出提示框并跳转到新页面即重定向到新页面
本文为大家介绍下使用PHP弹出提示框并跳转到新页面,也就是大家所认为的重定向,下面的示例大家可以参考下 这两天写一个demo,需要用到提示并跳转,主要页面要求不高,觉得没必要使用AJAX,JS等, ...
- ASP.NET 使用AJAX让GridView的数据行显示提示框(ToolTip)
介绍ASP.NET AJAX可以使你的web应用程序具有更丰富的功能和更多的用户响应. 本文中,我将演示如何通过ASP.NET AJAX的帮助,给像GridView这样的数据绑定控件的数据行增加pop ...
- Bootstrap提示框
前面的话 提示框是一个比较常见的功能,一般来说是鼠标移动到特定元素上时,显示相关的提示语.本文将详细介绍Bootstrap提示框 基本用法 Bootstrap框架中的提示框,结构非常简单,常常使用的是 ...
- .Net Core应用框架Util介绍(四)
上篇介绍了Util Angular Demo的目录结构和运行机制,本文介绍Util封装Angular的基本手法及背后的动机. Angular应用由Ts和Html两部分构成,本文介绍第一部分. Angu ...
- (转)基于Metronic的Bootstrap开发框架经验总结(6)--对话框及提示框的处理和优化
http://www.cnblogs.com/wuhuacong/p/4775282.html 在各种Web开发过程中,对话框和提示框的处理是很常见的一种界面处理技术,用得好,可以给用户很好的页面体验 ...
- JS组件系列——Bootstrap寒冬暖身篇:弹出框和提示框效果以及代码展示
前言:对于Web开发人员,弹出框和提示框的使用肯定不会陌生,比如常见的表格新增和编辑功能,一般常见的主要有两种处理方式:行内编辑和弹出框编辑.在增加用户体验方面,弹出框和提示框起着重要的作用,如果你的 ...
随机推荐
- linux 查看内存和cpu占用比较多的进程
1.可以使用一下命令查使用内存最多的10个进程 ps -aux | sort -k4nr | head -n 102. 可以使用一下命令查使用CPU最多的10个进程 ps ...
- Metlnfo CMS全版本漏洞收集
根据https://www.seebug.org/appdir/MetInfo 进行书写. [版本:Metlnfo 4.0] 漏洞标题:Metlnfo cms任意用户密码修改 漏洞文件:member/ ...
- 使用迭代法穷举1到N位最大的数
这是何海涛老师剑指offer上面第12题,这题首先注意不能使用整数int型作为操作对象,因为N很大时明显会溢出.这种大数据一般都是使用的字符串来表示. 直接法就是:1.针对字符串的加法,涉及循环进位及 ...
- linux下C语言实现的哈希链表【转】
转自:http://blog.chinaunix.net/uid-28458801-id-4276934.html 操作系统:ubuntu10.04 前言: 在稍微大点的项目中,基本都会遇到算 ...
- ubuntu 命令配置ip 网关 dns
如果是在虚拟机中使用Ubuntu,先设置好主机的网络,然后配置虚拟机Ubuntu的IP和网关 如果主机操作系统就是Ubuntu,请直接参照下文进行设置 内容如下: 1. 检验是否可以连通,就使用pin ...
- ansible command模块将返回值写入变量
ansible 中command模块支持 register参数将远程命令执行的输出结果存储在变量中,后续可以在when中对该变量进行检索确定下一步任务. --- - name: cat /etc/re ...
- C#子线程中更新ui
本文实例总结了C#子线程更新UI控件的方法,对于桌面应用程序设计的UI界面控制来说非常有实用价值.分享给大家供大家参考之用.具体分析如下: 一般在winform C/S程序中经常会在子线程中更新控件的 ...
- tomcat打开gzip、配置utf-8
在部署描述文件中配置如下内容:(web.xml) 打开gzip compression="on"配置utf-8 URIEncoding="UTF-8" < ...
- centos6.5 安装、启动vnc
一.安装vnc 1.确保当前账号是root2.查看本机是否已经安装vncserver rpm -qa|grep tigervnc 3.安装vncserver yum -y install tigerv ...
- Linux中常用命令 <一>
本笔记中记录的命令来源于 <Linux C 编程实战> ------------------------------------------------------------------ ...