如何在两个单元格之间传递数据

时间:2016-01-17 11:45:10

标签: ios swift uitableview uicollectionview

经过几个小时的谷歌搜索,似乎我需要社会的暗示。

所以问题是: 我有两个自定义原型单元格。第一个包含UICollectionView个12个单元格,第二个包含一个标签。

我的任务是将indexPath.rowcollectionView从第一个单元格传递到第二个单元格中的标签。

didSelectItemAtIndexPath:无效或我没有正确调整它。

非常感谢任何关于如何实施的想法!

这是我的代码(抱歉StackOverflow格式不佳)

    import UIKit

class MainTableViewController: UITableViewController {


    var storedOffsets = [Int: CGFloat]()


    var descrLabel = UILabel()


    override func viewDidLoad() {
        super.viewDidLoad()
    }

    override func preferredStatusBarStyle() -> UIStatusBarStyle {
        return .LightContent
    }

    override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return 2
    }

    override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {

        if indexPath.row == 0 {

            let cell = tableView.dequeueReusableCellWithIdentifier("MainCell", forIndexPath: indexPath) as! MainTableViewCell

            let bgImg = UIImageView(image: UIImage(named: "background"))
            bgImg.contentMode = UIViewContentMode.ScaleAspectFill
            cell.backgroundView = bgImg
            return cell
        }

        else {
            let cell = tableView.dequeueReusableCellWithIdentifier("DescriptionCell", forIndexPath: indexPath) as! DescriptionTableViewCell

            cell.descriptionLabel.text = self.descrLabel.text
            return cell
        }
    }

    override func tableView(tableView: UITableView, willDisplayCell cell: UITableViewCell, forRowAtIndexPath indexPath: NSIndexPath) {

        guard let tableViewCell = cell as? MainTableViewCell else { return }

        tableViewCell.setCollectionViewDataSourceDelegate(self, forRow: indexPath.row)
        tableViewCell.collectionViewOffset = storedOffsets[indexPath.row] ?? 0
    }

    override func tableView(tableView: UITableView, didEndDisplayingCell cell: UITableViewCell, forRowAtIndexPath indexPath: NSIndexPath) {

        guard let tableViewCell = cell as? MainTableViewCell else { return }

        storedOffsets[indexPath.row] = tableViewCell.collectionViewOffset
    }
}


extension MainTableViewController: UICollectionViewDelegate, UICollectionViewDataSource {

    func collectionView(collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
        return 12
    }

    func collectionView(collectionView: UICollectionView, cellForItemAtIndexPath indexPath: NSIndexPath) -> UICollectionViewCell {
        let cell = collectionView.dequeueReusableCellWithReuseIdentifier("MainCollectionViewCell", forIndexPath: indexPath) as! MainCollectionViewCell
         return cell
    }

    func collectionView(collectionView: UICollectionView, didSelectItemAtIndexPath indexPath: NSIndexPath) {
        print("Collection view at row \(collectionView.tag) selected index path \(indexPath.row)")
        self.descrLabel.text = "testText"
    }
}

1 个答案:

答案 0 :(得分:0)

我在操场上玩耍并制作了这个。 它没有经过测试,但应该会给你一些想法。

  protocol CustomDelegate{
    func passData(data: AnyObject)
}

class CustomColletionView : UICollectionView, UICollectionViewDelegate{
    var customDelegate : CustomDelegate!
    func didSelectItemAtIndexPath(collectionView : UICollectionView, indexPath : NSIndexPath){
        let cell = collectionView.cellForItemAtIndexPath(indexPath)
        let someData = ""
        customDelegate.passData(someData)
    }
}
class ViewController: UITableViewController, CustomDelegate{
    var labelCellData : AnyObject?{
        didSet{
            //reloadCell when data is received
            tableView.reloadRowsAtIndexPaths([NSIndexPath(forRow: 1, inSection: 0)], withRowAnimation: .Bottom)
        }
    }
    func passData(data: AnyObject) {
        labelCellData = data
    }
    override func viewDidLoad() {
        super.viewDidLoad()
        tableView.registerClass(CustomTableViewCell.self, forCellReuseIdentifier:"Indetifier1")
        tableView.registerClass(UITableViewCell.self, forCellReuseIdentifier: "simpleCell")
    }

    override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return 0
    }
    override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
        switch indexPath.row{
        case 0:
            //this should contain CustomCollectionView
            let cell = tableView.dequeueReusableCellWithIdentifier("Indetifier1") as! CustomTableViewCell
            cell.collectionView.customDelegate = self
            return cell
        case 1:
            let cell = tableView.dequeueReusableCellWithIdentifier("simpleCell")
            cell?.textLabel?.text = labelCellData as? String
            return cell!
        default:
            break
        }
        return UITableViewCell()
    }

}

class CustomTableViewCell: UITableViewCell {
    var collectionView : CustomColletionView!
    // You need to implement it

}