如何在UItableView中根据其内容拟合标签

时间:2016-09-10 11:32:36

标签: ios swift uitableview

我有tableview,我必须在单元格中显示产品

产品在索引路径中可以是单个或多个

示例:

 ["Burger","SandWitch"]

所以我需要根据tableview中的文字修复我的标签。

它没有工作。检查我的截图

我希望单元格高度应该根据标签的内容

检查屏幕截图文字在标签中是否大,因此无法在单元格中修复

enter image description here

如何实现这个目标?

3 个答案:

答案 0 :(得分:0)

使用此功能,您可以根据文本

设置标签
 func heightForView(text:String, #font:UIFont, #width:CGFloat) -> CGFloat{
        let label:UILabel = UILabel(frame: CGRectMake(0, 0, width, CGFloat.max))
        label.numberOfLines = 0
        label.lineBreakMode = NSLineBreakMode.ByWordWrapping
        label.font = font
        label.text = text

        label.sizeToFit()
        return label.frame.height
    }

    let font = UIFont(name: "Helvetica", size: 20.0)

    var height = heightForView("This is just a load of text", font: font, width: 100.0)

答案 1 :(得分:0)

最简单的解决方案:Object-C

tableView.rowHeight = UITableViewAutomaticDimension;
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
    UITableViewCell *cell = [[UITableViewCell alloc] init];
    cell.textLabel.text = @"text";
    cell.textLabel.numberOfLines = 0;
    return cell;
}

也许你需要这样的东西。斯威夫特3。

class ViewController: UIViewController, UITableViewDelegate, UITableViewDataSource {

    let tableView = UITableView()

    override func viewDidLoad() {
        super.viewDidLoad()

        tableView.delegate = self
        tableView.dataSource = self
        tableView.rowHeight = UITableViewAutomaticDimension
        tableView.estimatedRowHeight = 50
        tableView.frame = view.bounds
        view.addSubview(tableView)
    }    

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

    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return 5
    }

    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        let identifier = "some text ;)"
        let cell: CustomTableViewCell

        if let cel = tableView.dequeueReusableCell(withIdentifier: identifier) as? CustomTableViewCell {
            cell = cel
        } else {
            cell = CustomTableViewCell(style: .default, reuseIdentifier: identifier)
        }

        cell.labelValue = "what u want"

        return cell
    }
}

你必须继承UITableViewCell:

class CustomTableViewCell: UITableViewCell {

    var labelValue: String? {
        didSet { update() }
    }
    private let label = UILabel()

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

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

    private func install() {
        let padding: CGFloat = 6
        label.textColor = .black
        label.numberOfLines = 5
        //label.font = Fonts.Default(.Normal).getFont(17, forDifferentDevice: false)
        label.adjustsFontSizeToFitWidth = true
        label.minimumScaleFactor = 0.7
        label.lineBreakMode = .byTruncatingTail
        label.translatesAutoresizingMaskIntoConstraints = false
        contentView.addSubview(label)

        let cnt1 = NSLayoutConstraint(item: label, attribute: .leading, relatedBy: .equal, toItem: contentView, attribute: .leading, multiplier: 1, constant: padding)
        let cnt2 = NSLayoutConstraint(item: contentView, attribute: .trailing, relatedBy: .equal, toItem: label, attribute: .trailing, multiplier: 1, constant: padding)
        let cnt3 = NSLayoutConstraint(item: label, attribute: .top, relatedBy: .equal, toItem: contentView, attribute: .top, multiplier: 1, constant: padding)
        let cnt4 = NSLayoutConstraint(item: contentView, attribute: .bottom, relatedBy: .equal, toItem: label, attribute: .bottom, multiplier: 1, constant: padding)
        contentView.addConstraints([cnt1, cnt2, cnt3, cnt4])
    }

    private func update() {
        label.text = labelValue
    }

}

答案 2 :(得分:0)

使用NSAttributedString中的heightForRowAt来计算行的高度:

func tableView(tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat {
     let attString = NSAttributedString(string:"YOUR TEXT", attributes: [NSFontAttributeName: UIFont.systemFontOfSize(15.0)])
     var r: CGRect = attString.boundingRectWithSize(CGSizeMake(self.tableView.bounds.size.width, CGFLOAT_MAX), options: .UsesLineFragmentOrigin, context: nil)

     return r.size.height
}