您的位置:首页 > 移动开发 > Swift

Swift开发iOS应用(2)定制单元格

2016-02-24 22:48 351 查看

软硬件环境

OS X EI Capitan

Xcode 7.0.1

简介

前面一节我们实现了一个简单的列表,列表中的单元格是一串字符,在实际开发中一般不会如此简单,有可能还包括其它一些控件并且这些控件的位置还会各异,这时我们就需要对单元格进行自定义,本节我们将实现这个功能。



实现步骤

UI部分

新建一个工程,工程名为CustomCellDemo,模板选择Single View Application,上一节中创建的列表是通过在ViewController里选择Table View控件,然后配置代理,设置数据源来实现的,相对来说比较麻烦。本节将用一种全新的方法来实现,那就是TableViewController

首先从控件库中拖拽TableViewController到storyboard,将默认的ViewController前面的箭头移动到TableViewController,设置成初始控制器,然后删除默认的ViewController



接着将源码文件ViewController.swift也删除,删除时选择”Move to Trash”选项,如下图



导入图片

在左侧的文件导航栏里选中Assets.xcassets,然后从Finder里将图片拖动进来,我这里只准备了一张图片,@2x、@3x暂时没有



表格控制器

删除了默认的控制器,就需要再重新创建一个ViewController,如下图操作



关联视图和控制器

打开storyboard,选中ViewController,在右侧的Identity Inspector —> Custom Class —> Class里选择我们刚刚创建的CustomTableViewController



定制单元格

首先在storyboard里设置单元格的Identifier为”Cell”,Style选择”Custom”,



然后添加1个ImageView和2个UILabel控件,并调整他们的大小及位置。

创建单元格类



关联单元格与控制类



编辑CustomViewController.swift

准备2个数组来作为UILabel的数据源,图片就是之前导入进来的

var colors = ["Red","Yellow","Green","Gray","Orange","Black","White"]
var colorsChinese = ["红色","黄色","绿色","灰色","桔色","黑色","白色"]


重写方法tableView(tableView: UITableView,numberOfRowsInSection section: Int) —> Int,让其返回数据的元素个数,其实就是列表的行数

override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
// #warning Incomplete implementation, return the number of rows
return colors.count
}


最后重写方法tableView(tableView: UITableView,cellForRowAtIndexPath indexPath: NSIndexPath) —> UITableViewCell,这里需要返回我们自定义的单元格类,使用as进行强制转换,给单元格中的UIImageView和UILable赋值,完成单元格的自定义。

override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCellWithIdentifier("Cell", forIndexPath: indexPath) as! CustomTableViewCell

// Configure the cell...
cell.cellEnglish.text = colors[indexPath.row]
cell.cellChinese.text = colorsChinese[indexPath.row]
cell.cellImagge.image = UIImage(named: "penguin")

return cell
}


完成后,command + R运行下程序,在模拟器中查看效果

源码下载

https://github.com/djstava/SwiftForiOS/tree/master/CustomCellDemo
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息