徐高翔的个人网站

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

2015-10-12

软硬件环境

  • 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

推荐文章(由hexo文章推荐插件驱动)

使用支付宝打赏
使用微信打赏

请博主喝咖啡!