桌面视图中的UITextView没有根据内容调整大小

时间:2018-03-15 04:23:10

标签: ios swift uitableview uitextview

我有一个tableView和一个UITextView。我正在尝试将数据从JSON添加到表视图,但它不会根据大小缩小/扩展。我尝试了很多论坛和方法。

主要问题是 - 如果它随高度开始膨胀/收缩,它会停止缩小/扩展,反之亦然。机器人的高度和宽度不起作用。

这是因为,当我将UITextView的尾随和前导约束设置为单元格时,它开始处理高度但停止使用宽度。当我删除前导/尾随约束时,UITextView的内容超出了屏幕,并且不会成为多线,即不随高度扩展。我试过 -

How do I size a UITextView to its content?

How to resize table cell based on textview?

很多人喜欢这些。

我的一些代码 -

    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {

    let cell = tableView.dequeueReusableCell(withIdentifier: "Message") as! TextViewCell
    cell.customTextView.textColor = UIColor.white

    // Give a source to table view cell's label
    cell.customTextView.text = requestResponseArr[indexPath.row]
    cell.translatesAutoresizingMaskIntoConstraints = true
    cell.sizeToFit()        

    if (indexPath.row % 2 == 0) {
        cell.customTextView.backgroundColor = ConstantsChatBot.Colors.iMessageGreen
        cell.customTextView.textAlignment = .right
    } else {
        cell.customTextView.backgroundColor = ConstantsChatBot.Colors.ButtonBlueColor
        cell.customTextView.textAlignment = .left
    }

    return cell
}

func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat {
    return UITableViewAutomaticDimension
}

func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat {
    return UITableViewAutomaticDimension
}

在viewDidLoad() -

    override func viewDidLoad() {
    // RandomEstimatedRowHeight
    tableView.rowHeight = UITableViewAutomaticDimension
    tableView.estimatedRowHeight = 300
}

我不希望textview可以编辑。请回复swift,因为我不熟悉Objective C.谢谢

编辑:自定义单元代码

class TextViewCell: UITableViewCell {
@IBOutlet weak var customTextView: UITextView!

override func awakeFromNib() {
    super.awakeFromNib()
    // Initialization code
    customTextView.isScrollEnabled = false
}

override func setSelected(_ selected: Bool, animated: Bool) {
    super.setSelected(selected, animated: animated)
    // Configure the view for the selected state
}

}

4 个答案:

答案 0 :(得分:2)

我在UITextView内尝试了UITableViewCell

<强>约束

UITextView,顶部,底部和右侧为2,2和5,宽度为50. Font Size为13,Alignment为中心。将Outlet connection Width constraints作为txtVwWidthConst

<强>的UIViewController

@IBOutlet weak var tblView: UITableView!
var textWidthHeightDict = [Int : CGSize]()

override func viewDidAppear(_ animated: Bool) {

    stringValue = [0 : "qwer\nasdasfasdf", 1 : "qwe", 2 : "123123\nasdas\nwqe", 3 : "q\n3\n4", 4 : "klsdfjlsdhfjkhdjkshfjadhskfjhdjksfhkdjsahfjksdhfkhsdfhjksdfjkasklsdfjlsdhfjkhdjkshfjadhskfjhdjksfhkdjsahfjksdhfkhsdfhjksdfjkasklsdfjlsdhfjkhdjkshfjadhskfjhdjksfhkdjsahfjksdhfkhsdfhjksdfjkas"]

    for i in 0..<stringValue.count
    {
        GettingTextViewSize(getStr: stringValue[i]!, fontSize: 14, loopValue: i)
    }
    tblView.reloadData()
}

func GettingTextViewSize(getStr : String, fontSize: CGFloat, loopValue : Int)
{
    var textSize = (getStr as! NSString).size(withAttributes: [NSAttributedStringKey.font : UIFont.systemFont(ofSize: fontSize)])
    if textSize.width > self.tblView.frame.width
    {
        // IF STRING WIDTH GREATER THAN TABLEVIEW WIDTH
        let multipleValue = textSize.width / self.tblView.frame.width
        textSize.height = (textSize.height * (multipleValue + 1.0))
        textSize.width = self.tblView.frame.width

        textWidthHeightDict[loopValue] = textSize
    }
    else
    {
        textSize.height = textSize.height + 10 //ADDING EXTRA SPACE
        textSize.width = textSize.width + 10 //ADDING EXTRA SPACE

        textWidthHeightDict[loopValue] = textSize
    }
}


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

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

    return stringValue.count
}

func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {

    let cell = tableView.dequeueReusableCell(withIdentifier: "table", for: indexPath) as! TblTableViewCell

    cell.backgroundColor = cellBGColr[indexPath.row]

    cell.txtVw.inputAccessoryView = toolBar
    cell.txtVw.text = stringValue[indexPath.row]
    cell.txtVw.tag = indexPath.row
    cell.txtVwWidthConst.constant = (textWidthHeightDict[indexPath.row]?.width)!
    cell.selectionStyle = .none
    return cell
}

func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat {
    var heightVal = (textWidthHeightDict[indexPath.row])
    return heightVal!.height + 8 //ADDING EXTRA SPACE
}

<强>的UITableViewCell

class TblTableViewCell: UITableViewCell {
    @IBOutlet weak var txtVw: UITextView!
    @IBOutlet weak var txtVwWidthConst: NSLayoutConstraint!
    // TEXTVIEW WIDTH CONSTRAINTS    


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

<强>输出

enter image description here

注意

UITextView,我们必须计算字符串大小。但是,在UILabel中,这个概念非常简单。如果您有任何疑问,请与我们联系。

答案 1 :(得分:0)

您需要停用UItextView滚动。

textView.isScrollingEnabled = false

并在单元格中添加textview的顶部,底部,右侧和左侧约束。 并添加高度约束&gt; = 10

enter image description here

答案 2 :(得分:0)

isScrollEnabled

中禁用UITextView falsecellForRowAt

Demo Example

答案 3 :(得分:0)

您需要为textview设置所有四个约束,即前导,尾随,顶部和底部让我们说所有约束都设置为8。

它看起来如下所示: enter image description here

在GitHub here

上查看演示