委托UIView的didSet属性未在自定义UITableViewCell中调用

时间:2015-05-17 20:21:14

标签: ios uitableview swift

过去2个小时我一直在桌子上敲头试图解决这个问题,所以任何帮助都将不胜感激。

我正在使用CVCalendar(开发分支),我正在尝试将CalendarView置于自定义UITableViewCell中,以便我可以看起来像这样:

fullpixels

我遇到的问题是当我在自定义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
    }
}

1 个答案:

答案 0 :(得分:1)

您的println声明可能未达到,因为您的if条件if let calendarDelegate = newValue as? Delegate不正确,因为您在calenderDelegate传递的内容是CalenderCell,而不是{{1} }或Delegate(typealias)。

此外,您的CVCalendarViewDelegate不符合CalendarCellCVCalendarViewAppearanceDelegate

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