服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - IOS - iOS开发之路--微博“更多”页面

iOS开发之路--微博“更多”页面

2020-12-16 15:06iOS开发网 IOS

本文是IOS开发之路系列文章第五篇,主要讲诉了,如何制作微博的更多页面,并附上效果图及源码,需要的朋友可以参考下,希望能有所帮助

最终效果图:

iOS开发之路--微博“更多”页面
 

moreviewcontroller.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
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
//
// moreviewcontroller.m
// 20_帅哥no微博
//
// created by beyond on 14-8-4.
// copyright (c) 2014年 com.beyond. all rights reserved.
//
 
#import "moreviewcontroller.h"
 
@interface moreviewcontroller ()
{
  // more.plist根是字典,有两对key value,其中有一对是zh_cn,对应的值是数组,数组的长度就是有多少个分组,数组的每一个元素也是一个数组,
  
  // 由不同的分组,组成的数组
  nsarray *_groups;
}
 
 
@end
 
@implementation moreviewcontroller
 
- (void)viewdidload
{
  [super viewdidload];
  log(@"view %@",nsstringfromcgrect(self.view.frame)) ;
  
  // 1.设置导航条上面 右边的设置按钮
  [self setrightbarbuttonitem];
  
  // 2.加载more.plist
  [self loadplistofmore];
  
  // 3.设置tableview的全局背景
  [self settableviewglobalbg];
 
  // 4.添加 退出按钮 到tableview的最底部的tablefooterview
  [self addeixtbtnatbottom];
}
 
// 1,设置导航条上面 右边的按钮
- (void)setrightbarbuttonitem
{
  self.navigationitem.rightbarbuttonitem = [[uibarbuttonitem alloc] initwithtitle:@"设置" style:uibarbuttonitemstyleplain target:self action:@selector(settings)];
}
// 2,加载more.plist文件
- (void)loadplistofmore
{
  nsurl *url = [[nsbundle mainbundle] urlforresource:@"more" withextension:@"plist"];
  // 由一个个分组 组成的数组,分组的成员也就是数组,则一行行组成的数组
  _groups = [nsdictionary dictionarywithcontentsofurl:url][@"zh_cn"];
}
 
// 3,设置tableview的全局背景
- (void)settableviewglobalbg
{
  // 清除ios 7 中tableview顶部的多出的空白区域
  self.automaticallyadjustsscrollviewinsets = no;
  // 设置scrollview额外的滚动区域
//  self.tableview.contentinset = uiedgeinsetsmake(<#cgfloat top#>, <#cgfloat left#>, <#cgfloat bottom#>, <#cgfloat right#>)
  // 重要~ ~当tableview的样式为group时,如果想更换背景,必须先清除条纹状的自带的backgroundview,然后才可以设置tableview的背景颜色
  self.tableview.backgroundview = nil;
  self.tableview.backgroundcolor = kglobalbg;
  
  // 缩小每一分组之间的间距
  self.tableview.sectionheaderheight = 0;
  self.tableview.sectionfooterheight = 5;
}
 
// 4,创建退出按钮 并添加到tableview的最底部的tablefooterview
- (void)addeixtbtnatbottom
{
  // 1,创建一个footerview,将它作为tableview的tablefooterview
  uiview *footerview = [[uiview alloc] init];
  // tableview的tablefooterview的宽度固定是320,只有高度可调节
  footerview.frame = cgrectmake(0, 0, 320, 60);
  // 将刚才创建的footerview作为tableview的tablefooterview,目的是防止用户点击底部dockitem时不小心点到了退出按钮,因此要设置一个额外的空间,补充一下tablefooterview的宽度固定是320
  self.tableview.tablefooterview = footerview;
 
 
  
  
  // 2,创建退出按钮 并添加到tableview的最底部的tablefooterview
  uibutton *btnexit = [uibutton buttonwithtype:uibuttontypecustom];
  // footerview是作为tableview的tablefooterview存在,按钮是加到了footerview里面,这儿按钮的frame x 10 y 5是相对于footerview的
  btnexit.frame = cgrectmake(10, 5, 300, 40);
  // 按钮上字体大小
  btnexit.titlelabel.font = [uifont systemfontofsize:17];
  // 按钮的监听点击事件
  [btnexit addtarget:self action:@selector(exitbtnclick) forcontrolevents:uicontroleventtouchupinside];
  
  // 分类方法,设置按钮正常和高亮时背景图片(可拉伸)
  [btnexit setbtnbgimgfornormalandhighightedwithname:@"common_button_red.png"];
  // 设置按钮上的文字,最后一组,数组只有一行,每一行就是一个字典
  nsstring *btntitle = [_groups lastobject][0][@"name"];
  [btnexit settitle:btntitle forstate:uicontrolstatenormal];
  
  
  
  // 3,最重要的一步,将刚才创建的 退出按钮 添加到tableview的tablefooterview
  //[footerview addsubview:btnexit];
  [self.tableview.tablefooterview addsubview:btnexit];
 
}
// 响应点击设置点击事件
- (void)settings
{
  log(@"点击了设置按钮");
}
// 点击 退出按钮
- (void)exitbtnclick
{
  // cancelbuttontitle 黑色
  // destructivebuttontitle 红色
  // otherbuttontitles 灰白色
  uiactionsheet *actionsheet = [[uiactionsheet alloc] initwithtitle:@"确定退出此账号?" delegate:nil cancelbuttontitle:@"取消" destructivebuttontitle:@"红色" otherbuttontitles:@"其他", nil];
  
  // uiactionsheet最好是显示到window上面,这样就不怕点不中了,因为有时候控制器的view不一定占整个窗口大小
  [actionsheet showinview:self.view.window];
}
 
// 点击 设置按钮
- (void)setting
{
  log(@"设置");
}
// 代理方法,点击了某行时调用
- (void)tableview:(uitableview *)tableview didselectrowatindexpath:(nsindexpath *)indexpath
{
  [tableview deselectrowatindexpath:indexpath animated:yes];
}
 
#pragma mark - 数据源方法
// 共有多少组 最后一个组是特别的退出按钮,故不进入循环使用
- (nsinteger)numberofsectionsintableview:(uitableview *)tableview
{
  return _groups.count - 1;
}
 
// 每一组的行数
- (nsinteger)tableview:(uitableview *)tableview numberofrowsinsection:(nsinteger)section
{
  // 取得由每一行组成的数组
  nsarray *rows = _groups[section];
  // 返回该组的行数
  return rows.count;
}
 
// 每一组的每一行显示特有的内容
- (uitableviewcell *)tableview:(uitableview *)tableview cellforrowatindexpath:(nsindexpath *)indexpath
{
 
  static nsstring *cellid = @"beyond";
  // 1.先获得池中的cell
  uitableviewcell *cell = [tableview dequeuereusablecellwithidentifier:cellid];
  // 如果为空,才创建新的
  if (cell == nil) {
    // 创建新的cell
    cell = [[uitableviewcell alloc] initwithstyle:uitableviewcellstyledefault reuseidentifier:cellid];
    // 1.1.清除文本标签的背景
    cell.textlabel.backgroundcolor = [uicolor clearcolor];
    // 1.2.设置文本标签高亮时的文字颜色同样为默认的文字颜色 (不让它变色)
    cell.textlabel.highlightedtextcolor = cell.textlabel.textcolor;
    
    // 1.3.重点,创建时就,初始化cell的背景view和选中时的背景view
    uiimageview *bgimgview = [[uiimageview alloc] init];
    cell.backgroundview = bgimgview;
    
    uiimageview *selectedbgimgview = [[uiimageview alloc] init];
    cell.selectedbackgroundview = selectedbgimgview;
  }
  // 2.设置cell独一无二的内容
  // 设置显示的标题文字 第几组-->第几行--->字典
  cell.textlabel.text = _groups[indexpath.section][indexpath.row][@"name"];
  
  // 3.设置cell的背景图片
  // 先取出cell背景view
  uiimageview *bgimgview = (uiimageview *)cell.backgroundview;
  uiimageview *selectedbgimgview = (uiimageview *)cell.selectedbackgroundview;
  
  // 分情况得出cell的背景图片文件名
  // 该组中,由每一行组成的数组
  nsarray *rows = _groups[indexpath.section];
  // 得到该组的,总行数
  int rownum = rows.count;
  nsstring *name = nil;
  
  if (rownum == 1) {
    // 如果所在组只有一行,使用四角全是半角的图片
    name = @"common_card_background.png";
  } else if (indexpath.row == 0) {
    // 如果所在组不只一行,且当前行是所在组的第一行,使用上半为圆角的图片
    name = @"common_card_top_background.png";
  } else if (indexpath.row == rownum - 1) {
    // 如果所在组不只一行,且当前行是所在组的最后一行,使用下半为圆角的图片
    name = @"common_card_bottom_background.png";
  } else { // 中间
    // 如果所在组不只一行,且当前行不在组的第一行也不在组的最后一行,使用四周无圆角的图片
    name = @"common_card_middle_background.png";
  }
  
  // 设置cell的正常和选中时的背景图片
  bgimgview.image = [uiimage imagestretchedwithname:name];
  selectedbgimgview.image = [uiimage imagestretchedwithname:[name filenameinsertsuffixbeforeextension:@"_highlighted"]];
  
  // 4.设置最右边的箭头指示器,分文字和图片两种情况讨论
  if (indexpath.section == 2) {
    // 如果是第2组 ,则显示文字,"阅读模式 - 主题"
    uilabel *label = [[uilabel alloc] init];
    // 清除标签背景色
    label.backgroundcolor = [uicolor clearcolor];
    // 标签文字大小
    label.font = [uifont systemfontofsize:13];
    // 标签文字颜色
    label.textcolor = [uicolor graycolor];
    // 标签文字靠右
    label.textalignment = nstextalignmentright;
    // 标签frame的宽高
    label.bounds = cgrectmake(0, 0, 100, 30);
    // 该组的第1行显示 "有图模式" ,第2行显示 "经典主题"
    label.text = (indexpath.row == 0) ? @"有图模式" : @"经典主题";
    // 最后将自定义最右边的view设置为cell的附属view
    cell.accessoryview = label;
  } else {
    // 如果是其他的组,显示向右的图片箭头
    cell.accessoryview = [[uiimageview alloc] initwithimage:[uiimage imagenamed:@"common_icon_arrow.png"]];
  }
  // 5.返回cell
  return cell;
}
 
@end

『更多』页面的数据来源more.plist

iOS开发之路--微博“更多”页面

延伸 · 阅读

精彩推荐
  • IOS谈一谈iOS单例模式

    谈一谈iOS单例模式

    这篇文章主要和大家谈一谈iOS中的单例模式,单例模式是一种常用的软件设计模式,想要深入了解iOS单例模式的朋友可以参考一下...

    彭盛凇11872021-01-19
  • IOSiOS逆向教程之logify跟踪方法的调用

    iOS逆向教程之logify跟踪方法的调用

    这篇文章主要给大家介绍了关于iOS逆向教程之logify跟踪方法调用的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学...

    Mr.Guo11472021-04-28
  • IOSxcode8提交ipa失败无法构建版本问题的解决方案

    xcode8提交ipa失败无法构建版本问题的解决方案

    xcode升级到xcode8后发现构建不了新的版本。怎么解决呢?下面小编给大家带来了xcode8提交ipa失败无法构建版本问题的解决方案,非常不错,一起看看吧...

    Cinna丶7542021-02-03
  • IOSiOS10 Xcode8适配7个常见问题汇总

    iOS10 Xcode8适配7个常见问题汇总

    这篇文章主要为大家详细汇总了iOS10 Xcode8适配7个常见问题,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    索马里猫10332021-02-01
  • IOSiOS常见的几个修饰词深入讲解

    iOS常见的几个修饰词深入讲解

    这篇文章主要给大家介绍了关于iOS常见的几个修饰词的相关资料,iOS修饰词包括assign、weak、strong、retain、copy、nonatomic、atomic、readonly、readwrite,文中通过示...

    郡王丶千夜7422021-05-10
  • IOSIOS网络请求之AFNetWorking 3.x 使用详情

    IOS网络请求之AFNetWorking 3.x 使用详情

    本篇文章主要介绍了IOS网络请求之AFNetWorking 3.x 使用详情,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    总李写代码6892021-03-04
  • IOSiOS中时间与时间戳的相互转化实例代码

    iOS中时间与时间戳的相互转化实例代码

    这篇文章主要介绍了iOS中时间与时间戳的相互转化实例代码,非常具有实用价值,需要的朋友可以参考下。...

    张无忌!4812021-03-09
  • IOSiOS APP实现微信H5支付示例总结

    iOS APP实现微信H5支付示例总结

    这篇文章主要介绍了iOS APP实现微信H5支付示例总结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下...

    一张小A11332021-06-01