web-dev-qa-db-fra.com

Ajouter une étiquette de texte et un bouton à la cellule tableview dynamique par programme avec Swift

J'ai une table dynamique et une cellule prototype qui affiche un tableau. Ma question est comment puis-je ajouter un bouton qui affiche différents noms sur chaque cellule à gauche de la cellule, puis une étiquette à droite affichant les informations du tableau Merci! :RÉ

Alors, imaginez que ceci est la cellule ci-dessous:

Côté gauche: Bouton (informations sur le tableau) <-------------------> Côté droit: TextLabel (informations sur le tableau)

5
Don Draper

Vous pouvez implémenter comme ça

let titleArray = ["a", "b", "c"]

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

func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
    //return no.of cell do you want
}

func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell
{
    let cellHeight = tableView(self.tableView, heightForRowAtIndexPath: NSIndexPath(forRow: indexPath.row, inSection: indexPath.section))
    var cell = CustomCell(frame: CGRectMake(0, 0, self.view.frame.width, cellHeight), title: titleArray[indexPath.row])
    cell.cellLabel.text = //labelText
    cell.cellButton.addTarget(self, action: "buttonPressed:", forControlEvents: UIControlEvents.TouchUpInside)

    return cell
}

class CustomCell: UITableViewCell {
    var cellButton: UIButton!
    var cellLabel: UILabel!

    init(frame: CGRect, title: String) {
        super.init(style: UITableViewCellStyle.Default, reuseIdentifier: "cell")

        cellLabel= UILabel(frame: CGRectMake(self.frame.width - 100, 10, 100.0, 40))
        cellLabel.textColor = UIColor.blackColor()
        cellLabel.font = //set font here

        cellButton = UIButton(frame: CGRectMake(5, 5, 50, 30))
        cellButton.setTitle(title, forState: UIControlState.Normal)

        addSubview(cellLabel)
        addSubview(cellButton)
    }

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

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

J'ai la solution à votre question, veuillez suivre les étapes ci-dessous

var data = ["iPad", "iPhone", "iWatch", "iPod", "iMac"]
var buttonData = ["US","China","London","Canada","Japan"];


//UITableViewDataSource Methods

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

 func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int 
 {
    return data.count
 }

 func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell
 {

    var cell = tableView.dequeueReusableCellWithIdentifier("Cell", forIndexPath: indexPath) as UITableViewCell

    var label = UILabel(frame: CGRectMake(280.0, 14.0, 100.0, 30.0))
    label.text = data[indexPath.row]
    label.tag = indexPath.row
    cell.contentView.addSubview(label)


    let btn = UIButton.buttonWithType(UIButtonType.Custom) as UIButton
    btn.backgroundColor = UIColor.greenColor()
    btn.setTitle(buttonData[indexPath.row], forState: UIControlState.Normal)
    btn.frame = CGRectMake(0, 5, 80, 40)
    btn.addTarget(self, action: "buttonPressed:", forControlEvents: UIControlEvents.TouchUpInside)
    btn.tag = indexPath.row
    cell.contentView.addSubview(btn)

    return cell
 }

 //Button Action is
 func buttonPressed(sender:UIButton!)
 {
    let buttonRow = sender.tag
    println("button is Pressed")
    println("Clicked Button Row is",buttonRow)
 }
0
user3182143