簡體   English   中英

Swift-滾動時出現tableViewCell問題

[英]Swift - tableViewCell issue when scrolling

我正在使用swift創建一個聊天應用程序。 在故事板上,我有一個View Controller負責顯示消息。 我有3個swift文件:

  • ChatingViewController:與情節提要上的View Controller關聯的類

  • CustomChatingTableViewController

  • CellChatingTableViewCell

每個消息都顯示在一個單元格中。 我以編程方式創建tableView。

-ChatingViewController

            import UIKit

            class ChatingViewController: UIViewController {

            var messageController = [[String:String]]()

            var tableViewController = CustomChatingTableViewController()

            override func viewDidLoad() {

                let sizeTableView = CGSize(width: view.frame.size.width - 2 * margin, height: view.frame.size.height - sizeTextField.height - 2 * margin - self.navigationController!.navigationBar.frame.size.height)
                let originTableView = CGPoint(x: margin, y: 2 * margin + self.navigationController!.navigationBar.frame.size.height)

                tableViewController.tableView.frame = CGRect(origin: originTableView, size: sizeTableView)
                tableViewController.tableView.registerClass(CellChatingTableViewCell.self, forCellReuseIdentifier: "Cell")
                tableViewController.data = messageController
                tableViewController.tableView.separatorStyle = .None

                view.addSubview(tableViewController.tableView)
    }

-CustomChatingTableViewController

import UIKit

class CustomChatingTableViewController: UITableViewController {


    var data:[[String:String]]!

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

        return data.count
    }


    override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
        var cell = tableView.dequeueReusableCellWithIdentifier("Cell") as CellChatingTableViewCell

        cell.setCell(data[indexPath.row]["name"] as String!, date: data[indexPath.row]["date"] as String!, message: data[indexPath.row]["message"] as String!)

        return cell


    }

    override func tableView(tableView: UITableView, heightForRowAtIndexPath indexPath: NSIndexPath) -> CGFloat {
        return 150
    }

}

** -CellChatingTableViewCell **

import UIKit
class CellChatingTableViewCell: UITableViewCell {

    var date =  UILabel()
    var message = UILabel()

func setCell(name:String,date:String,message:String){


    let imageContainerMessage = UIImage(named: "orange.png")!.stretchableImageWithLeftCapWidth(24, topCapHeight: 15)


    self.date.font = UIFont(name: "Arial", size: 10)
    self.date.text = date
    self.date.numberOfLines = 0
    self.date.lineBreakMode = NSLineBreakMode.ByWordWrapping
    let sizeDateLabelMax = CGSizeMake(self.frame.size.width, 9999)
    let expectedSizeDate = self.date.sizeThatFits(sizeDateLabelMax)
    self.date.frame = CGRect(origin: CGPoint.zeroPoint, size: expectedSizeDate)



    self.message.font = UIFont(name: "Arial", size: 15)
    self.message.text = message
    self.message.numberOfLines = 0
    self.message.lineBreakMode = NSLineBreakMode.ByWordWrapping
    let sizeMessageLabelMax = CGSizeMake(self.frame.size.width, 9999)
    let expectedSizeMessage = self.message.sizeThatFits(sizeMessageLabelMax)
    self.message.frame = CGRect(origin: CGPoint(x: 15, y: 10), size: expectedSizeMessage)

    var imageContainer = UIImageView(frame: CGRect(origin: CGPoint(x: 0, y: expectedSizeDate.height + 5), size:
        CGSizeMake(expectedSizeMessage.width + 25, expectedSizeMessage.height +  25)))
    imageContainer.image = imageContainerMessage


    self.addSubview(self.date)
    self.addSubview(imageContainer)
    imageContainer.addSubview(self.message)
}
}

當我加載ViewController時,一切工作正常,但是當我滾動tableView時,它變得可怕:

滾動之前:

在此處輸入圖片說明

滾動后:

在此處輸入圖片說明

有什么建議嗎?

提前致謝

cellForRowAtIndexPath ,您正在重用單元格。 但是,然后在自定義UITableViewCell ,您要多次添加( self.addSubViewself.dateself.message (yikes),並添加imageContainer新實例。

您應該在重新添加之前清除單元格,或者使用新數據使它們無效,但不要再次執行self.addSubView

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM