iOS开发之UITabBarController和UICollectionView的使用
这一篇要记录的是iOS开发中UITabBarController控件和UICollectionView控件的使用。APP跑起来之后的效果例如以下图:
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">
UITabBarController控件,即上图中页面下部能够切换到不同页面去的选项卡。UICollectionView即上右图中的View。以格子的形式展现出来。
本篇主要用到了例如以下几个知识点:
1、给ViewController加上UITabBarController控件
2、给ViewController加上UINavigationController控件
3、使用UITableView和UICollectionView展示列表
4、使用plist文件,在代码中读取plist文件并载入到UITableView和UICollectionView中
以下就一步步完毕这个项目:
1、首先在xcode中新建项目,取名为TabBarControllerTest
2、切换到Main.storyboard,然后选中ViewController视图,在菜单条中选择Editor-->Embed in-->Tab Bar Controller,这一步操作完毕后。故事板中的界面例如以下所看到的:
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">
3、以下给ViewController设置TabBar,在故事板中选中ViewController下方的TabBar。然后在xcode右側的属性栏中。设置System item为Contacts,例如以下图所看到的:
4、给ViewController加上导航栏。
选中故事板中的ViewController,然后在菜单条中选择Editor-->Embed in-->NavigationController,操作完毕后界面例如以下所看到的:
然后选中ViewController视图顶部的Navigation,在xcode右側的属性栏中配置title为“联系人”。
5、新增一个代表近期联系人的ViewController。
在控件区拖入一个ViewController到故事板中。然后鼠标右键按住。从Tab Bar Controller视图拖到刚刚新建的ViewController视图上,例如以下图所看到的:
松开鼠标后。在出现的对话框中,选择view controller,例如以下图所看到的:
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">
如今故事板中的视图是以下这样:
採用和上面的步骤同样的方法,选中我们新建的那个ViewController视图底部的TabBar。然后在xcode右側的视图中配置System item为Recents。
6、为新增的那个ViewController加上导航栏。
选中故事板中我们新增的ViewController,然后在菜单中选择Editor-->Embed in-->Navigation Controller,然后像前面的操作那样设置导航栏的标题为“近期联系人”。操作完毕后的故事板应该例如以下图所看到的:
到这里能够先执行程序看看效果。尽管没有数据显示,可是我们的TabBar还是能够切换的,切换到不同的Tab之后。导航栏上的标题也会随着切换。例如以下图所看到的:
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">
7、给页面中增加数据。
首先是联系人列表的数据,这个在前面的博文中已有说到,这里就不具体说了,这里我们须要新建一个单元格类ContactCell继承自UITableViewCell,ContactCell.h的代码例如以下:
#import <UIKit/UIKit.h> @interface ContactCell : UITableViewCell @property (weak, nonatomic) IBOutlet UIImageView *avatarImage; @property (weak, nonatomic) IBOutlet UILabel *nameLabel; @property (weak, nonatomic) IBOutlet UILabel *phoneLabel; @end
然后在ViewController中载入数据。ViewController.h文件的代码例如以下:
#import <UIKit/UIKit.h> @interface ViewController : UIViewController <UITableViewDataSource, UITableViewDelegate> @property (weak, nonatomic) IBOutlet UITableView *tableView; @end
这里主要是ViewController.m中的代码。我们在当中载入了外部plist文件中的数据,先贴上ViewController.m文件的代码:
#import "ViewController.h"
#import "ContactCell.h" @interface ViewController () @end @implementation ViewController NSArray *avatarArr;
NSArray *nameArr;
NSArray *phoneArr;
static NSString *identifier = @"ContactCell"; - (void)viewDidLoad {
[super viewDidLoad];
// Do any additional setup after loading the view, typically from a nib.
[self loadDataFromFile];
//设置tableView的代理和数据源
self.tableView.delegate = self;
self.tableView.dataSource = self;
} #pragma mark 从plist中载入数据
- (void)loadDataFromFile {
NSString *filePath = [[NSBundle mainBundle] pathForResource:@"contacts" ofType:@"plist"];
NSDictionary *dict = [[NSDictionary alloc] initWithContentsOfFile:filePath];
avatarArr = [dict objectForKey:@"avatars"];
nameArr = [dict objectForKey:@"names"];
phoneArr = [dict objectForKey:@"phones"];
} #pragma mark 返回TableView的行数
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {
return [nameArr count];
} #pragma mark 返回某个单元格
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {
ContactCell *cell = [self.tableView dequeueReusableCellWithIdentifier:identifier forIndexPath:indexPath];
cell.avatarImage.image = [UIImage imageNamed:[avatarArr objectAtIndex:indexPath.row]];
cell.nameLabel.text = [nameArr objectAtIndex:indexPath.row];
cell.phoneLabel.text = [phoneArr objectAtIndex:indexPath.row];
return cell;
} #pragma mark 返回单元格的高度
- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath {
return 80;
} #pragma mark 设置选中某个单元格后。背景色恢复初始状态
- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath {
[self.tableView deselectRowAtIndexPath:indexPath animated:YES];
} - (void)didReceiveMemoryWarning {
[super didReceiveMemoryWarning];
// Dispose of any resources that can be recreated.
} @end
从plist文件里载入数据。主要使用的NSBundle类的pathForResource方法。这里我们的plist文件名称为contacts,文件内容例如以下:
8、给CollectionView载入数据
为了给CollectionView载入数据,首先得新建一个代表CollectionView单元格的类,这里取名为RecentCell,且这个类继承自UICollectionViewCell,RecentCell.h代码例如以下:
#import <UIKit/UIKit.h> @interface RecentCell : UICollectionViewCell @property (weak, nonatomic) IBOutlet UIImageView *avatarImage; @property (weak, nonatomic) IBOutlet UILabel *nameLabel; @end
然后还得新建一个装载了CollectionView的ViewController,这里取名为RecentViewController,RecentViewController.h代码例如以下:
#import <UIKit/UIKit.h> @interface RecentViewController : UIViewController <UICollectionViewDataSource, UICollectionViewDelegate> @property (weak, nonatomic) IBOutlet UICollectionView *recentCollectionView; @end
里面仅包括一个代表CollectionView的变量,RecentViewController.m文件的代码例如以下:
#import "RecentViewController.h"
#import "RecentCell.h" @interface RecentViewController () @end @implementation RecentViewController NSArray *recentAvatarArr;
NSArray *recentNameArr;
static NSString *identifier = @"RecentCell"; - (void)viewDidLoad {
[super viewDidLoad];
// Do any additional setup after loading the view.
[self loadDataFromFile];
self.recentCollectionView.delegate = self;
self.recentCollectionView.dataSource = self;
} #pragma mark 从文件里载入数据
- (void)loadDataFromFile {
NSString *filePath = [[NSBundle mainBundle] pathForResource:@"contacts" ofType:@"plist"];
NSDictionary *dict = [[NSDictionary alloc] initWithContentsOfFile:filePath];
recentAvatarArr = [dict objectForKey:@"avatars"];
recentNameArr = [dict objectForKey:@"names"];
} #pragma mark 一个section中的item数目
- (NSInteger)collectionView:(UICollectionView *)collectionView numberOfItemsInSection:(NSInteger)section {
return [recentAvatarArr count];
} #pragma mark 返回某个单元格
- (UICollectionViewCell *)collectionView:(UICollectionView *)collectionView cellForItemAtIndexPath:(NSIndexPath *)indexPath {
RecentCell *cell = [self.recentCollectionView dequeueReusableCellWithReuseIdentifier:identifier forIndexPath:indexPath];
cell.avatarImage.image = [UIImage imageNamed:[recentAvatarArr objectAtIndex:indexPath.row]];
cell.nameLabel.text = [recentNameArr objectAtIndex:indexPath.row];
return cell;
} - (void)didReceiveMemoryWarning {
[super didReceiveMemoryWarning];
// Dispose of any resources that can be recreated.
} @end
事实上UICollectionView的使用方法和UITableView的使用方法类似,都是须要在头文件里实现数据源和托付协议。然后在.m文件里实现协议里的某几个方法来处理视图中显示的数据。
以下总结下在项目过程中须要注意的点:
(1)要注意在xcode的属性视图中给单元格指定的标识一定要和代码中的相应
(2)不要忘了将代码中声明的代表视图对象的变量,和真正的视图联系起来
(3)要给UITableView和UICollectionView等集合视图加入数据。一定不要忘了在头文件里实现协议
最新文章
- 【CC评网】2013.第38周 要阅读 要有好工具
- phalcon: tasks MainTask.php命令行工具
- json字符串转json对象的方法
- maven属性
- MyBatis+Spring 事务管理
- java异常类的使用
- Linux Kernel ‘kvm_set_memory_region()’函数本地提权漏洞
- 【warning】clang the linker unused
- php下redis的安装教程
- C#调用Java的WebService添加SOAPHeader验证
- 【20190226】JavaScript-知识点记录:dom0级事件,dom2级事件
- HTML 5 拖放
- RocketMQ最佳实战
- hdoj5785
- android开发学习——day4
- JavaScript里的创建对象(一)
- 梯度提升树GBDT算法
- CF&;&;CC百套计划3 Codeforces Round #204 (Div. 1) E. Jeff and Permutation
- js 中 0 和 null 、";"; Boolean 值关系
- 区间DP的摸索
热门文章
- python插件,pycharm基本用法,markdown文本编写,jupyter notebook的基本操作汇总
- 数据结构( Pyhon 语言描述 ) — — 第7章:栈
- shell-code-2-传参
- redis安装与安全设置
- 推荐SQL Server Management Studio以及Visual Studio下的免费的插件 ApexSQL Complete
- Python第三方库之openpyxl(12)
- 在LoadRunner中执行命令行程序之:popen()取代system()
- 使用Unity做2.5D游戏教程(二)
- 【Luogu】P3402最长公共子序列(LCS->;nlognLIS)
- UOJ 34 多项式乘法 ——NTT