Swift 3 - 第一个单元格已展开的可扩展表格视图单元格

nob*_*are 2 ios swift swift3

我正在使用 Swift 3。

我已经按照本教程来获取它,以便我可以点击表视图单元格,该单元格将展开以显示更多信息。

https://www.youtube.com/watch?v=VWgr_wNtGPM&t=294s

我的问题是:如何在视图加载时扩展第一个单元格(即用户不必单击以查看该单元格展开)但所有其他行为保持不变(例如,如果再次单击它,它会崩溃)?

UITableViewCell

import UIKit

class ResultsCell: UITableViewCell {

    @IBOutlet weak var introPara : UITextView!
    @IBOutlet weak var section_heading : UILabel!

    class var expandedHeight : CGFloat { get { return 200.0 } }
    class var defaultHeight : CGFloat { get { return 44.0 } }
    var frameAdded = false


    required init?(coder aDecoder: NSCoder) {
        super.init(coder: aDecoder)
    }

    override func awakeFromNib() {
        super.awakeFromNib()
        section_heading.translatesAutoresizingMaskIntoConstraints = false
    }

    func checkHeight() {
        introPara.isHidden = (frame.size.height < ResultsCell.expandedHeight)
    }

    func watchFrameChanges() {
        if(!frameAdded) {
            addObserver(self, forKeyPath: "frame", options: .new, context: nil)
            checkHeight()
        }
    }

    func ignoreFrameChanges() {
        if(frameAdded){
            removeObserver(self, forKeyPath: "frame")
        }
    }

    deinit {
        print("deinit called");
        ignoreFrameChanges()
    }

    // when our frame changes, check if the frame height is appropriate and make it smaller or bigger depending
    override func observeValue(forKeyPath keyPath: String?, of object: Any?, change: [NSKeyValueChangeKey : Any]?, context: UnsafeMutableRawPointer?) {
        if keyPath == "frame" {
            checkHeight()
        }
    }

}
Run Code Online (Sandbox Code Playgroud)

UITableViewController

// class declaration and other methods above here...

override func numberOfSections(in tableView: UITableView) -> Int {
    return 1
}

// number of rows in the table view
override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
    return section_heading.count
}

// return the actual view for the cell
override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
    let resultcell = tableView.dequeueReusableCell(withIdentifier: "resultCellTemplate", for: indexPath) as! ResultsCell
    resultcell.section_heading.text = section_heading[indexPath.row]
    resultcell.introPara.attributedText = contentParagraphs[indexPath.row]

    return resultcell
}

// when a cell is clicked
override func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
    let previousIndexPath = selectedIndexPath

    // the row is already selected, then we want to collapse the cell
    if indexPath == selectedIndexPath {
        selectedIndexPath = nil
    } else { // otherwise, we expand that cell
        selectedIndexPath = indexPath
    }

    var indexPaths : Array<IndexPath> = []

    // only add a previous one if it exists
    if let previous = previousIndexPath {
        indexPaths.append(previous)
    }
    if let current = selectedIndexPath {
        indexPaths.append(current)
    }

    // reload the specific rows
    if indexPaths.count > 0 {
        tableView.reloadRows(at: indexPaths, with: .automatic)
    }
}

override func tableView(_ tableView: UITableView, willDisplay cell: UITableViewCell, forRowAt indexPath: IndexPath) {
    (cell as! ResultsCell).watchFrameChanges()
}

override func tableView(_ tableView: UITableView, didEndDisplaying cell: UITableViewCell, forRowAt indexPath: IndexPath) {
    (cell as! ResultsCell).ignoreFrameChanges()

}

override func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat {
    if indexPath == selectedIndexPath {
        return ResultsCell.expandedHeight
    } else {
        return ResultsCell.defaultHeight
    }
}
Run Code Online (Sandbox Code Playgroud)

所以这按预期工作。

在此处输入图片说明

但是我如何制作它以便第一个单元格已经扩展?

谢谢你的帮助。

Cas*_*gen 5

我觉得你没有完全理解你自己的代码,但由于你确实在你的问题上付出了很多努力,我会给你一个提示。

在顶部的 UITableViewController 中,您初始化 selectedIndexPath ,它应该看起来像

var selectedIndexPath: IndexPath?
Run Code Online (Sandbox Code Playgroud)

您可以将其设置为这样的默认值

var selectedIndexPath: IndexPath? = IndexPath(row: 0, section: 0)
Run Code Online (Sandbox Code Playgroud)

因此 (row: 0, section: 0) 处的单元格将默认展开。