自定义UITableViewCell

自定义UITableViewCell

在过去的2个小时里,我一直在脑海中摸索,试图弄清楚这一点,因此,我们将不胜感激。

我正在使用CVCalendar(develop分支),正在尝试将CalendarView放在自定义UITableViewCell内,以便使它看起来像这样:

我面临的问题是,当我在自定义UITableViewCell中调用self.calendarView.calendarDelegate = self时,它没有设置委托属性

我知道没有设置它,因为我已将println放置在未输出的代表didSet属性内。

这是CalendarView内部的CalendarViewDelegate出口

// MARK: - Calendar View Delegate

@IBOutlet weak var calendarDelegate: AnyObject? {
    set {
        if let calendarDelegate = newValue as? Delegate {
            delegate = calendarDelegate
            println("delegate did set property called")
        }
    }

    get {
        return delegate
    }
}

这是我正在使用的自定义UITableViewCell的代码。
import UIKit

class CalendarCell: UITableViewCell {

    var calendarView: CVCalendarView!

    override func awakeFromNib() {
        super.awakeFromNib()
        // Initialization code
    }

    override func setSelected(selected: Bool, animated: Bool) {
        super.setSelected(selected, animated: animated)

        // Configure the view for the selected state
    }

    override init(style: UITableViewCellStyle, reuseIdentifier: String?) {
        super.init(style: style, reuseIdentifier: reuseIdentifier)

        backgroundColor = UIColor.redColor()
        selectionStyle = .None

        self.calendarView = CVCalendarView(frame: self.frame)
        self.calendarView.calendarDelegate = self
        self.calendarView.calendarAppearanceDelegate = self
        self.calendarView.animatorDelegate = self
        contentView.addSubview(calendarView)
    }

    required init(coder aDecoder: NSCoder) {
        fatalError("init(coder:) has not been implemented")
    }

    override func layoutSubviews() {
        super.layoutSubviews()
        self.calendarView.commitCalendarViewUpdate()
    }
}

这是我的UITableViewController代码:
import UIKit

class CalendarTableViewController: UITableViewController {

    @IBOutlet var myTableView: UITableView!

    var items = ["Apple", "Banana"];

    override func viewDidLoad() {
        super.viewDidLoad()

        self.myTableView.registerClass(CalendarCell.self, forCellReuseIdentifier: NSStringFromClass(CalendarCell))
        self.myTableView.registerClass(UITableViewCell.self, forCellReuseIdentifier: "Cell")
        self.myTableView.dataSource = self
    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }

    func creatHeaderCell() -> UITableViewCell {
        var headerCell = self.myTableView.dequeueReusableCellWithIdentifier(NSStringFromClass(CalendarCell)) as! CalendarCell
        return headerCell
    }

    // MARK: - Table view data source

    override func tableView(tableView: UITableView, heightForRowAtIndexPath indexPath: NSIndexPath) -> CGFloat {
        if (indexPath.section == 0) {
            return 300
        }

        return 44
    }

    override func numberOfSectionsInTableView(tableView: UITableView) -> Int {
        return 2
    }

    override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        switch (section) {
        case 0:
            return 1
        default:
            return items.count
        }
    }

    override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
        if (indexPath.section == 0) {
            return self.creatHeaderCell()
        }

        let cell = self.myTableView.dequeueReusableCellWithIdentifier("Cell", forIndexPath: indexPath) as! UITableViewCell
        cell.textLabel!.text = "Thomas"

        // Configure the cell...

        return cell
    }
}

最佳答案

您的println语句可能未达到,因为您的if条件if let calendarDelegate = newValue as? Delegate不成立,因为您作为calenderDelegate传递的是CalenderCell,而不是DelegateCVCalendarViewDelegate(类型别名)。

此外,您的CalendarCell不符合CVCalendarViewAppearanceDelegateCVCalendarViewAnimatorDelegate

您必须使您的单元格符合那些协议,才能将它们设置为委托。

10-04 21:41