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

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开发中的FirstResponder第一响应对象

    解析iOS开发中的FirstResponder第一响应对象

    这篇文章主要介绍了解析iOS开发中的FirstResponder第一响应对象,包括View的FirstResponder的释放问题,需要的朋友可以参考下...

    一片枫叶4662020-12-25
  • IOSIOS开发之字典转字符串的实例详解

    IOS开发之字典转字符串的实例详解

    这篇文章主要介绍了IOS开发之字典转字符串的实例详解的相关资料,希望通过本文能帮助到大家,让大家掌握这样的方法,需要的朋友可以参考下...

    苦练内功5832021-04-01
  • IOSiOS通过逆向理解Block的内存模型

    iOS通过逆向理解Block的内存模型

    自从对 iOS 的逆向初窥门径后,我也经常通过它来分析一些比较大的应用,参考一下这些应用中某些功能的实现。这个探索的过程乐趣多多,不仅能满足自...

    Swiftyper12832021-03-03
  • IOSiOS布局渲染之UIView方法的调用时机详解

    iOS布局渲染之UIView方法的调用时机详解

    在你刚开始开发 iOS 应用时,最难避免或者是调试的就是和布局相关的问题,下面这篇文章主要给大家介绍了关于iOS布局渲染之UIView方法调用时机的相关资料...

    windtersharp7642021-05-04
  • IOSIOS 屏幕适配方案实现缩放window的示例代码

    IOS 屏幕适配方案实现缩放window的示例代码

    这篇文章主要介绍了IOS 屏幕适配方案实现缩放window的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要...

    xiari5772021-06-01
  • IOSiOS 雷达效果实例详解

    iOS 雷达效果实例详解

    这篇文章主要介绍了iOS 雷达效果实例详解的相关资料,需要的朋友可以参考下...

    SimpleWorld11022021-01-28
  • IOSiOS中tableview 两级cell的展开与收回的示例代码

    iOS中tableview 两级cell的展开与收回的示例代码

    本篇文章主要介绍了iOS中tableview 两级cell的展开与收回的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    J_Kang3862021-04-22
  • IOS关于iOS自适应cell行高的那些事儿

    关于iOS自适应cell行高的那些事儿

    这篇文章主要给大家介绍了关于iOS自适应cell行高的那些事儿,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的...

    daisy6092021-05-17