Swift中定制单元格

/

软硬件环境

  • 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的数据源,图片就是之前导入进来的

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

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

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

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

  1. override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
  2. let cell = tableView.dequeueReusableCellWithIdentifier("Cell", forIndexPath: indexPath) as! CustomTableViewCell
  3. // Configure the cell...
  4. cell.cellEnglish.text = colors[indexPath.row]
  5. cell.cellChinese.text = colorsChinese[indexPath.row]
  6. cell.cellImagge.image = UIImage(named: "penguin")
  7. return cell
  8. }

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

源码下载

https://github.com/djstava/SwiftForiOS/tree/master/CustomCellDemo

转载请注明作者和出处,并添加本页链接。
原文链接:http://xugaoxiang.com/post/53

给我留言