如何从弹出窗口内的 uicollectionview 中单击按钮将数据发送到主视图控制器中的表格单元格?
我有一个带有自定义单元格的 UITableView。当我点击单元格内的“1”时,它会弹出一个弹出窗口。弹出框使用带有 UICollectionView 的 UIView 作为子视图。集合视图内部是自定义单元格,每个单元格都有一个按钮。所需的行为是单击弹出窗口中的按钮并让该按钮通过委托执行功能,并在主视图控制器中的自定义 UITableViewCell 内设置按钮的按钮标题。
主视图控制器:
import UIKit
class MainViewController: UIViewController, UITableViewDataSource, UITableViewDelegate, ListItemCellDelegate, PopoverCellDelegate {
...
func setPriority(buttonTitle: String) {
print("Button Pressed")
}
PopoverCell:
import UIKit
import Foundation
protocol PopoverCellDelegate: class {
func setPriority(buttonTitle: String)
}
class PopoverCell: UICollectionViewCell {
weak var delegate: PopoverCellDelegate?
let cellView: UIView = {
let view = UIView()
view.backgroundColor = UIColor.white
view.setCellShadow()
return view
}()
let priorityButton: UIButton = {
let button = UIButton(type: .custom)
// button.setImage(UIImage(named: "UnChecked"), for: .normal)
// button.setImage(UIImage(named: "Checked"), for: .selected)
button.frame = CGRect(x: 0, y: 0, width: 60, height: 60)
button.setTitleColor(.black, for: .normal)
button.backgroundColor = UIColor.white
button.layer.borderWidth = 2
button.layer.borderColor = UIColor.black.cgColor
button.titleLabel?.font = UIFont.init(name: "Avenir Next", size: 24)
return button
}()
override func awakeFromNib() {
super.awakeFromNib()
// Initialization code
}
override func prepareForReuse() {
super.prepareForReuse()
self.delegate = nil
}
override init(frame: CGRect) {
super.init(frame: frame)
setupCell()
priorityButton.addTarget(self, action: #selector(setPriority), for: .touchUpInside)
}
required init?(coder aDecoder: NSCoder) {
fatalError("init(coder:) has not been implemented")
}
func setupCell() {
cellView.translatesAutoresizingMaskIntoConstraints = false
priorityButton.translatesAutoresizingMaskIntoConstraints = false
addSubview(cellView)
cellView.addSubview(priorityButton)
cellView.heightAnchor.constraint(greaterThanOrEqualToConstant: 60).isActive = true
cellView.setAnchor(top: topAnchor, left: leftAnchor, bottom: bottomAnchor, right: rightAnchor, paddingTop: 8, paddingLeft: 4, paddingBottom: 8, paddingRight: 4)
priorityButton.setAnchor(top: cellView.topAnchor, left: cellView.leftAnchor, bottom: cellView.bottomAnchor, right: cellView.rightAnchor, paddingTop: 0, paddingLeft: 0, paddingBottom: 0, paddingRight: 0, width: 60, height: 60)
priorityButton.centerXAnchor.constraint(equalTo: cellView.centerXAnchor).isActive = true
}
@objc private func setPriority() {
if let title = priorityButton.currentTitle {
print(title)
self.delegate?.setPriority(buttonTitle: title)
}
}
}