一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - IOS - iOS實現步驟進度條功能實例代碼

iOS實現步驟進度條功能實例代碼

2021-05-17 16:35獨木舟的木 IOS

這篇文章主要給大家介紹了關于iOS實現步驟進度條功能的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

前言

在開發中,我們經常在很多場景下需要用到進度條,比如文件的下載,或者文件的上傳等。 本文主要給大家介紹的是一個步驟進度條效果,步驟進度條效果參考

iOS實現步驟進度條功能實例代碼

ios uikit 框架中并沒有提供類似的控件,我們可以使用 uiprogressview、uiview、uilabel 組合實現步驟進度條效果。

  • uiprogressview——實現水平的進度條效果;
  • uiview——把uiview裁剪成圓形,實現索引節點效果;
  • uilabel——每個節點下面的提示文字。

源碼

將步驟進度條封裝成一個 hqlstepview 類,它是 uiview 的子類。

hqlstepview.h 文件

?
1
2
3
4
5
6
7
8
9
10
11
#import <uikit/uikit.h>
 
@interface hqlstepview : uiview
 
// 指定初始化方法
- (instancetype)initwithframe:(cgrect)frame titlesarray:(nsarray *)titlesarray stepindex:(nsuinteger)stepindex;
 
// 設置當前步驟
- (void)setstepindex:(nsuinteger)stepindex animation:(bool)animation;
 
@end

hqlstepview.m 文件

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
#import "hqlstepview.h"
 
// 步驟條主題色
#define tint_color [uicolor colorwithred:35/255.f green:135/255.f blue:255/255.f alpha:1]
 
@interface hqlstepview ()
 
@property (nonatomic, copy) nsarray *titlesarray;
@property (nonatomic, assign) nsuinteger stepindex;
 
@property (nonatomic, strong) uiprogressview *progressview;
@property (nonatomic, strong) nsmutablearray *circleviewarray;
@property (nonatomic, strong) nsmutablearray *titlelabelarray;
@property (nonatomic, strong) uilabel *indicatorlabel;
 
@end
 
@implementation hqlstepview
 
#pragma mark - init
 
- (instancetype)initwithframe:(cgrect)frame titlesarray:(nsarray *)titlesarray stepindex:(nsuinteger)stepindex {
 self = [super initwithframe:frame];
 if (self) {
 _titlesarray = [titlesarray copy];
 _stepindex = stepindex;
 
 // 進度條
 [self addsubview:self.progressview];
 
 for (nsstring *title in _titlesarray) {
  
  // 圓圈
  uiview *circle = [[uiview alloc] initwithframe:cgrectmake(0, 0, 13, 13)];
  circle.backgroundcolor = [uicolor lightgraycolor];
  circle.layer.cornerradius = 13.0f / 2;
  [self addsubview:circle];
  [self.circleviewarray addobject:circle];
  
  // 標題
  uilabel *label = [[uilabel alloc] init];
  label.text = title;
  label.font = [uifont systemfontofsize:14];
  label.textalignment = nstextalignmentcenter;
  [self addsubview:label];
  [self.titlelabelarray addobject:label];
 }
 
 // 當前索引數字
 [self addsubview:self.indicatorlabel];
 }
 return self;
}
 
// 布局更新頁面元素
- (void)layoutsubviews {
 nsinteger perwidth = self.frame.size.width / self.titlesarray.count;
 
 // 進度條
 self.progressview.frame = cgrectmake(0, 0, self.frame.size.width - perwidth, 1);
 self.progressview.center = cgpointmake(self.frame.size.width / 2, self.frame.size.height / 4);
 
 cgfloat startx = self.progressview.frame.origin.x;
 for (int i = 0; i < self.titlesarray.count; i++) {
 // 圓圈
 uiview *cycle = self.circleviewarray[i];
 if (cycle) {
  cycle.center = cgpointmake(i * perwidth + startx, self.progressview.center.y);
 }
 
 // 標題
 uilabel *label = self.titlelabelarray[i];
 if (label) {
  label.frame = cgrectmake(perwidth * i, self.frame.size.height / 2, self.frame.size.width / self.titlesarray.count, self.frame.size.height / 2 );
 }
 }
 self.stepindex = self.stepindex;
}
 
#pragma mark - custom accessors
 
- (uiprogressview *)progressview {
 if (!_progressview) {
 _progressview = [[uiprogressview alloc] initwithprogressviewstyle:uiprogressviewstyledefault];
 _progressview.progresstintcolor = tint_color;
 _progressview.progress = self.stepindex / ((self.titlesarray.count - 1) * 1.0);
 }
 return _progressview;
}
 
- (uilabel *)indicatorlabel {
 if (!_indicatorlabel) {
 _indicatorlabel = [[uilabel alloc] initwithframe:cgrectmake(0, 0, 23, 23)];
 _indicatorlabel.textcolor = tint_color;
 _indicatorlabel.textalignment = nstextalignmentcenter;
 _indicatorlabel.backgroundcolor = [uicolor whitecolor];
 _indicatorlabel.layer.cornerradius = 23.0f / 2;
 _indicatorlabel.layer.bordercolor = [tint_color cgcolor];
 _indicatorlabel.layer.borderwidth = 1;
 _indicatorlabel.layer.maskstobounds = yes;
 }
 return _indicatorlabel;
}
 
- (nsmutablearray *)circleviewarray {
 if (!_circleviewarray) {
 _circleviewarray = [[nsmutablearray alloc] initwithcapacity:self.titlesarray.count];
 }
 return _circleviewarray;
}
 
- (nsmutablearray *)titlelabelarray {
 if (!_titlelabelarray) {
 _titlelabelarray = [[nsmutablearray alloc] initwithcapacity:self.titlesarray.count];
 }
 return _titlelabelarray;
}
 
// 設置當前進度索引,更新圓形圖片、文本顏色、當前索引數字
- (void)setstepindex:(nsuinteger)stepindex {
 for (int i = 0; i < self.titlesarray.count; i++) {
 uiview *cycle = self.circleviewarray[i];
 uilabel *label = self.titlelabelarray[i];
 if (stepindex >= i) {
  cycle.backgroundcolor = tint_color;
  label.textcolor = tint_color;
 } else {
  cycle.backgroundcolor = [uicolor lightgraycolor];
  label.textcolor = [uicolor lightgraycolor];
 }
 }
}
 
#pragma mark - public
 
- (void)setstepindex:(nsuinteger)stepindex animation:(bool)animation {
 if (stepindex < self.titlesarray.count) {
 // 更新顏色
 self.stepindex = stepindex;
 // 設置進度條
 [self.progressview setprogress:stepindex / ((self.titlesarray.count - 1) * 1.0) animated:animation];
 // 設置當前索引數字
 self.indicatorlabel.text = [nsstring stringwithformat:@"%lu", stepindex + 1];
 self.indicatorlabel.center = ((uiview *)[self.circleviewarray objectatindex:stepindex]).center;
 }
}
 
@end

接口調用:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
- (void)viewdidload {
 [super viewdidload];
 
 // 初始化
 _hqlstepview = [[hqlstepview alloc] initwithframe:cgrectmake(0, 200, self.view.frame.size.width, 60) titlesarray:@[@"第一步", @"第二步", @"第三步"] stepindex:0];
 [self.view addsubview:_hqlstepview];
}
 
- (void)viewdidappear:(bool)animated {
 [super viewdidappear:animated];
 
 // 設置當前步驟,步驟索引=數組索引
 [_hqlstepview setstepindex:0 animation:yes];
}

效果:

iOS實現步驟進度條功能實例代碼

因為 uiprogressview 實現的水平進度條高度值默認為1,設置frame是無效的。可以通過仿射變換的方式增加它的高度。

第三方框架

參考:

總結:

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對服務器之家的支持。

原文鏈接:https://www.jianshu.com/p/fb471ca68a1b

延伸 · 閱讀

精彩推薦
  • IOSiOS中MD5加密算法的介紹和使用

    iOS中MD5加密算法的介紹和使用

    MD5加密是最常用的加密方法之一,是從一段字符串中通過相應特征生成一段32位的數字字母混合碼。對輸入信息生成唯一的128位散列值(32個字符)。這篇文...

    LYSNote5432021-02-04
  • IOS詳解iOS中多個網絡請求的同步問題總結

    詳解iOS中多個網絡請求的同步問題總結

    這篇文章主要介紹了詳解iOS中多個網絡請求的同步問題總結,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧...

    liang199111312021-03-15
  • IOSiOS開發技巧之狀態欄字體顏色的設置方法

    iOS開發技巧之狀態欄字體顏色的設置方法

    有時候我們需要根據不同的背景修改狀態欄字體的顏色,下面這篇文章主要給大家介紹了關于iOS開發技巧之狀態欄字體顏色的設置方法,文中通過示例代碼...

    夢想家-mxj8922021-05-10
  • IOSiOS中UILabel實現長按復制功能實例代碼

    iOS中UILabel實現長按復制功能實例代碼

    在iOS開發過程中,有時候會用到UILabel展示的內容,那么就設計到點擊UILabel復制它上面展示的內容的功能,也就是Label長按復制功能,下面這篇文章主要給大...

    devilx12792021-04-02
  • IOSiOS開發之視圖切換

    iOS開發之視圖切換

    在iOS開發中視圖的切換是很頻繁的,獨立的視圖應用在實際開發過程中并不常見,除非你的應用足夠簡單。在iOS開發中常用的視圖切換有三種,今天我們將...

    執著丶執念5282021-01-16
  • IOSiOS自定義UICollectionViewFlowLayout實現圖片瀏覽效果

    iOS自定義UICollectionViewFlowLayout實現圖片瀏覽效果

    這篇文章主要介紹了iOS自定義UICollectionViewFlowLayout實現圖片瀏覽效果的相關資料,需要的朋友可以參考下...

    jiangamh8882021-01-11
  • IOSiOS實現控制屏幕常亮不變暗的方法示例

    iOS實現控制屏幕常亮不變暗的方法示例

    最近在工作中遇到了要將iOS屏幕保持常亮的需求,所以下面這篇文章主要給大家介紹了關于利用iOS如何實現控制屏幕常亮不變暗的方法,文中給出了詳細的...

    隨風13332021-04-02
  • IOSiOS中滑動控制屏幕亮度和系統音量(附加AVAudioPlayer基本用法和Masonry簡單使用)

    iOS中滑動控制屏幕亮度和系統音量(附加AVAudioPlayer基本用法和

    這篇文章主要介紹了iOS中滑動控制屏幕亮度和系統音量(附加AVAudioPlayer基本用法和Masonry簡單使用)的相關資料,需要的朋友可以參考下...

    CodingFire13652021-02-26
主站蜘蛛池模板: 国产99区| 亚洲剧情在线观看 | 成人在线观看免费视频 | 喜欢老头吃我奶躁我的动图 | 四虎成人免费 | 99热综合在线 | 91麻豆国产 | 二次元美女内裤凹陷太深 | 日本私人影院 | 国产精品成人va在线观看 | 亚洲欧美精品久久 | 唯美 清纯 另类 亚洲制服 | 日本一区二区三区视频在线观看 | 国产成人精品999在线 | 免费特黄一级欧美大片在线看 | 亚洲AV无码专区国产乱码网站 | 91av免费 | 日本在线播放 | 91精品国产美女福到在线不卡 | 99在线观看免费视频 | 国产91精品露脸国语对白 | 草女人逼 | 国产欧美视频高清va在线观看 | 天天天做天天天天爱天天想 | 99精品国产成人一区二区在线 | 欧美日韩视频在线第一区二区三区 | 美女禁区视频免费观看精选 | 国产成人精品一区二三区2022 | 男人的天堂久久精品激情 | 精品国产麻豆免费人成网站 | 欧美一区二区三区免费看 | 亚洲AV精品一区二区三区不卡 | 美日韩在线观看 | 久久久这里有精品999 | 99久久免费国产香蕉麻豆 | 欧美亚洲一区二区三区 | 51国产午夜精品免费视频 | 亚洲高清中文字幕 | 男人叼女人的痛爽视频免费 | 男人的天堂在线观看视频不卡 | 国产精品久久久久一区二区三区 |