更改自定义UITableViewCell类

时间:2018-06-10 17:20:39

标签: swift uitableview

我有2个类 - 一个UITableViewController和一个自定义的UITableViewCell。我想更改UITableViewController的单元格高度,因此我实现了以下内容:

override func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat {
    return tableView.frame.height*(1/12)
}

它有效!细胞高度发生变化。现在,我进入我的自定义UITableViewCell类

import UIKit

class TableViewCell: UITableViewCell {

    var time:UILabel = UILabel()
    var name:UILabel = UILabel()

    override init(style: UITableViewCellStyle, reuseIdentifier: String?) {
        super.init(style: style, reuseIdentifier: reuseIdentifier) // the common code is executed in this super call

        let imageView = UIImageView(frame: CGRect(x: 0, y: 0, width: self.frame.width*0.22, height: self.frame.height))
        imageView.image = UIImage(named: "Person")
        imageView.contentMode = .scaleAspectFit
        imageView.isUserInteractionEnabled = true
        self.addSubview(imageView)

        let tap = UITapGestureRecognizer(target: self, action: #selector(signIn))
        imageView.addGestureRecognizer(tap)

        name = UILabel(frame: CGRect(x: self.frame.width*0.22, y: 0, width: self.frame.width*0.78, height: self.frame.height*0.7))
        name.textColor = UIColor.gray
        name.font = UIFont(name: name.font!.fontName, size: 30)
        name.adjustsFontSizeToFitWidth = true
        self.addSubview(name)

        time = UILabel(frame: CGRect(x: self.frame.width*0.22, y: self.frame.height*0.65, width: self.frame.width*0.78, height: self.frame.height*0.3))
        time.textColor = UIColor.gray
        time.font = UIFont(name: time.font!.fontName, size: 15)
        time.adjustsFontSizeToFitWidth = true
        self.addSubview(time)
    }

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

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

    @objc func signIn(tap: UITapGestureRecognizer) {
        let tappedImage = tap.view as! UIImageView
        tappedImage.image = UIImage(named: "PersonClocked")
    }

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

        // Configure the view for the selected state
    }

}

所以,我现在编辑控制器内的函数来调用单元格。

override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { 
    let cell:TableViewCell = tableView.dequeueReusableCell(withIdentifier: "cell", for: indexPath) as! TableViewCell

    cell.layer.borderColor = UIColor.red.cgColor
    cell.layer.borderWidth = 1

    cell.name.text = names[indexPath.row]
    cell.time.text = times[indexPath.row]

    return cell
}

我希望现在一切顺利!但是,它并没有。无论出于何种原因,方法都按此顺序调用......

tableview(cellForRowAt) -> TableViewCell(override init) -> tableView(heightForRowAt)'

所以,当我去运行它时,它看起来像下面。使用Swift&Apple的默认运行时tableView创建单元格,然后更改单元格大小,但单元格内的所有内容仍然是原始默认值的大小。我需要它是细胞的大小。有任何想法吗? 注意 - 我添加了一个边框,以便您可以看到单元格与项目的大小。

1 个答案:

答案 0 :(得分:1)

框架布局无助于创建动态高度表,您必须使用动态tableViewCells并使用约束创建单元格的contentView以获取当前内容的高度变化

//

override init(style: UITableViewCellStyle, reuseIdentifier: String?) {
    super.init(style: style, reuseIdentifier: reuseIdentifier) // the common code is executed in this super call

    let imageView = UIImageView(frame: CGRect(x: 0, y: 0, width: self.frame.width*0.22, height: self.frame.height))
    imageView.image = UIImage(named: "Person")
    imageView.contentMode = .scaleAspectFit
    imageView.isUserInteractionEnabled = true
    self.addSubview(imageView)

    let tap = UITapGestureRecognizer(target: self, action: #selector(signIn))
    imageView.addGestureRecognizer(tap)

    name = UILabel(frame: CGRect(x: self.frame.width*0.22, y: 0, width: self.frame.width*0.78, height: self.frame.height*0.7))
    name.textColor = UIColor.gray
    name.font = UIFont(name: name.font!.fontName, size: 30)
    name.adjustsFontSizeToFitWidth = true
    self.addSubview(name)

    time = UILabel(frame: CGRect(x: self.frame.width*0.22, y: self.frame.height*0.65, width: self.frame.width*0.78, height: self.frame.height*0.3))
    time.textColor = UIColor.gray
    time.font = UIFont(name: time.font!.fontName, size: 15)
    time.adjustsFontSizeToFitWidth = true
    self.addSubview(time)

    imageView.translatesAutoresizingMaskIntoConstraints = false
    name.translatesAutoresizingMaskIntoConstraints = false
    time.translatesAutoresizingMaskIntoConstraints = false

    imageView.centerYAnchor.constraint(equalTo: contentView.centerYAnchor,constant: 0).isActive = true
    imageView.leadingAnchor.constraint(equalTo: contentView.leadingAnchor,constant: 20).isActive = true
    imageView.heightAnchor.constraint(equalToConstant: 30).isActive = true
    imageView.widthAnchor.constraint(equalToConstant: 30).isActive = true

    name.topAnchor.constraint(equalTo: contentView.topAnchor,constant: 20).isActive = true
    name.leadingAnchor.constraint(equalTo: imageView.leadingAnchor,constant: 20).isActive = true
    name.trailingAnchor.constraint(equalTo: contentView.trailingAnchor,constant: -20).isActive = true

    time.topAnchor.constraint(equalTo: name.topAnchor,constant: 20).isActive = true
    time.leadingAnchor.constraint(equalTo: imageView.leadingAnchor,constant: 20).isActive = true
    time.trailingAnchor.constraint(equalTo: contentView.trailingAnchor,constant: -20).isActive = true
    time.bottomAnchor.constraint(equalTo: contentView.bottomAnchor,constant: -20).isActive = true

}

//

将其放在viewDidLoad

 tableview.estimatedRowHeight = 100 
 tableview.rowHeight = UITableViewAutomaticDimension

并且不实施heightForRowAt方法