iOS 自定义步骤进度条
新项目要做入驻功能,其中包括一个入住流程,类似登录或者注册流程如下图。

之前想着用自己绘图来做,可是又懒不想多写代码,所以就想着能不能用进度条来做。
1.用进度条做的首先要解决的是进度条的高度问题,可以通过仿射变换来扩大高度。
progressView.transform = CGAffineTransformMakeScale(1.0f,2.0f);
2.用进度条要设置进度progress要与按钮对应
通过步骤的索引来改变进度的值和按钮的图片。由于按钮的左右有间隔所以要注意-1、0和最后一个的progress值。
3.扩展
看有一些类似查公交、车站运行的APP有的可以点击站点,所以就用按钮来做,这样可以扩展。
4.代码
// // StepProgressView.h // CustomProgress // // Created by City--Online on 15/12/12. // Copyright © 2015年 City--Online. All rights reserved. // #import <UIKit/UIKit.h> @interface StepProgressView : UIView @property (nonatomic,assign) NSInteger stepIndex; +(instancetype)progressViewFrame:(CGRect)frame withTitleArray:(NSArray *)titleArray; @end
//
// StepProgressView.m
// CustomProgress
//
// Created by City--Online on 15/12/12.
// Copyright © 2015年 City--Online. All rights reserved.
//
#import "StepProgressView.h"
;
@interface StepProgressView ()
@property (nonatomic,strong) UIProgressView *progressView;
//用UIButton防止以后有点击事件
@property (nonatomic,strong) NSMutableArray *imgBtnArray;
@end
@implementation StepProgressView
+(instancetype)progressViewFrame:(CGRect)frame withTitleArray:(NSArray *)titleArray
{
StepProgressView *stepProgressView=[[StepProgressView alloc]initWithFrame:frame];
//进度条
stepProgressView.progressView=[[UIProgressView alloc]initWithFrame:CGRectMake(, , frame.size.width, )];
stepProgressView.progressView.progressViewStyle=UIProgressViewStyleBar;
stepProgressView.progressView.transform = CGAffineTransformMakeScale(1.0f,2.0f);
stepProgressView.progressView.progressTintColor=[UIColor redColor];
stepProgressView.progressView.trackTintColor=[UIColor blueColor];
stepProgressView.progressView.progress=0.5;
[stepProgressView addSubview:stepProgressView.progressView];
stepProgressView.imgBtnArray=[[NSMutableArray alloc]init];
float _btnWidth=frame.size.width/(titleArray.count);
; i<titleArray.count; i++) {
//图片按钮
UIButton *btn=[UIButton buttonWithType:UIButtonTypeCustom];
[btn setImage:[UIImage imageNamed:@"0.png"] forState:UIControlStateNormal];
[btn setImage:[UIImage imageNamed:@"1.png"] forState:UIControlStateSelected];
btn.frame=CGRectMake(_btnWidth/+_btnWidth*i-imgBtnWidth/, , imgBtnWidth, imgBtnWidth);
btn.selected=YES;
[stepProgressView addSubview:btn];
[stepProgressView.imgBtnArray addObject:btn];
//文字
UILabel *titleLabel=[[UILabel alloc]initWithFrame:CGRectMake(btn.center.x-_btnWidth/, frame.size.height-, _btnWidth, )];
titleLabel.text=[titleArray objectAtIndex:i];
[titleLabel setTextColor:[UIColor blackColor]];
titleLabel.textAlignment=NSTextAlignmentCenter;
titleLabel.font=[UIFont systemFontOfSize:];
[stepProgressView addSubview:titleLabel];
}
stepProgressView.stepIndex=-;
return stepProgressView;
}
-(void)setStepIndex:(NSInteger)stepIndex
{
// 默认为-1 小于-1为-1 大于总数为总数
_stepIndex=stepIndex<-?-:stepIndex;
_stepIndex=stepIndex >=_imgBtnArray.count-?_imgBtnArray.count-:stepIndex;
float _btnWidth=self.bounds.size.width/(_imgBtnArray.count);
; i<_imgBtnArray.count; i++) {
UIButton *btn=[_imgBtnArray objectAtIndex:i];
if (i<=_stepIndex) {
btn.selected=YES;
}
else{
btn.selected=NO;
}
}
) {
self.progressView.progress=0.0;
}
)
{
self.progressView.progress=1.0;
}
else
{
self.progressView.progress=(0.5+_stepIndex)*_btnWidth/self.frame.size.width;
}
}
@end
5.使用和效果
NSArray *arr=@[@"区宝时尚",@"区宝时尚",@"时尚",@"区宝时尚",@"时尚"];
StepProgressView *stepView=[StepProgressView progressViewFrame:CGRectMake(, , self.view.bounds.size.width, ) withTitleArray:arr];
stepView.stepIndex=;
[self.view addSubview:stepView];

补充:上面的代码有一个bug,例如stepIndex=-1时,_stepIndex=并不等-1,原来数组的count返回的是NSUInteger而stepIndex是NSInteger类型,所以需要强制转换一下
stepIndex=stepIndex<-?-:stepIndex;
_stepIndex = stepIndex >= (NSInteger)(_imgBtnArray.count-) ? _imgBtnArray.count-:stepIndex;
iOS 自定义步骤进度条的更多相关文章
- Xamarin iOS教程之进度条和滚动视图
Xamarin iOS教程之进度条和滚动视图 Xamarin iOS 进度条 进度条可以看到每一项任务现在的状态.例如在下载的应用程序中有进度条,用户可以很方便的看到当前程序下载了多少,还剩下多少.Q ...
- 自定义环形进度条RoundProgressBar
一.效果图: Canvas画圆环说明: 圆环宽度不必在意,只是画笔宽度设置后达到的效果. 二.实现步骤 1.自定义View-RoundProgressBar 2.设置属性resources(decle ...
- 步骤进度条 css
用css写一个简单的步骤进度条 html代码: <h4>南京游玩</h4> <ul class="step-list"> <li> ...
- Android 自定义水平进度条的圆角进度
有时项目中需要实现水平圆角进度,如下两种,其实很简单 下面开始看代码,先从主界面布局开始看起: <?xml version="1.0" encoding=" ...
- iOS开发:代码通用性以及其规范 第一篇(附带,自定义UITextView\进度条\双表显示\瀑布流 代码设计思路)
在iOS团队开发中,我见过一些人的代码,也修改过他们的代码.有的人的代码写的非常之规范.通用,几乎不用交流,就可以知道如何修改以及在它基础上扩展延生.有的人的代码写的很垃圾,一眼看过去,简直会怀疑自己 ...
- 自定义带进度条的WebView , 增加获取web标题和url 回掉
1.自定义ProgressWebView package com.app.android05; import android.content.Context; import android.graph ...
- 【Android 应用开发】 自定义 圆形进度条 组件
转载著名出处 : http://blog.csdn.net/shulianghan/article/details/40351487 代码下载 : -- CSDN 下载地址 : http://down ...
- ProgressBar学习笔记,自定义横向进度条的样式(包含ActionBar上面的进度条)
点显示进度条后→ android:max="100" 进度条的最大值 android:progress 进度条已经完成的进度值 android:progressDrawab ...
- android新闻项目、饮食助手、下拉刷新、自定义View进度条、ReactNative阅读器等源码
Android精选源码 Android仿照36Kr官方新闻项目课程源码 一个优雅美观的下拉刷新布局,众多样式可选 安卓版本的VegaScroll滚动布局 android物流详情的弹框 健身饮食记录助手 ...
随机推荐
- double? int?
C# 值类型加上?表示可空类型(Nullable 结构),就是一种特殊的值类型,它的值可以为null 例: int? float? stirng? double?
- sharepoint 2007 update sharepoint 2013 found old privillege not availabel
我们下面提及的升级方式是: 2007 > 2010 > 2013 > 2013: classic authentication à claims based authenticati ...
- iOS View 外层奇怪的黑线
最近碰到一个问题,当时是为了建了一个能自动适应内容的 Label.根据内容,我计算出需要的尺寸,然后把新尺寸设置给 Label. 但是显示的时候,一个奇怪的现象出现了,Label 的顶端总是有一条浅浅 ...
- 重新使用Eclipse建立安卓工程遇到的问题
很早之前用过Eclipse建立安卓工程,很久没用了,最近打算用Eclipse开发安卓程序,我是用谷歌提供的Eclipse集成环境建立的安卓工程,发现有了一些变化,而且遇到一点问题,这几天不断学习,终于 ...
- Delphi XE7的安卓程序如何调用JAVA的JAR,使用JAVA的类?
本文使用工具和全部源码下载: http://download.csdn.net/detail/sunylat/8190765 为什么我们要在Delphi XE7的安卓程序调用JAVA的JAR,使用JA ...
- Unity下的开发框架--适应web和微端游戏异步资源请求的框架
一. 内容简介: 1. 框架对Web与微端游戏特性的支持: Web和微端游戏最重要的特性是,资源是持续从服务器上即时下载下来的.而保证体验流畅的关键就是保证资源下载分散到持续的体验过程中,并保 ...
- MySql数据库备份的几种方式
mysqldump工具备份 备份整个数据库 $> mysqldump -u root -h host -p dbname > backdb.sql 备份数据库中的某个表 $> mys ...
- Prim算法---最小生成树
最小生成树的Prim算法也是贪心算法的一大经典应用.Prim算法的特点是时刻维护一棵树,算法不断加边,加的过程始终是一棵树. Prim算法过程: 一条边一条边地加, 维护一棵树. 初始 E = {}空 ...
- 蹭你wifi后 我竟然干了这样的事
前言:故事发生在前两天,我们去参观工业园区内一家电商公司. 去参观他们公司的时候,我说要用下无线网,他们技术说密码就是他们的网站域名,我一脸懵逼表示我不知道域名,然后对方接过我手机给我连上了他们wif ...
- logstash5.5.0同步sql server数据
注意:jdbc.conf和jdbc.sql文件编码都为ANSI jdbc.conf内容如下: input { stdin { } jdbc { jdbc_connection_string => ...