Я пытаюсь настроить UICollectionViewCell
с помощью material-components
под названием MDCCardCollectionCell
. Но когда я реализую его успешно, то есть, когда я нажимаю на каждую ячейку, я вижу анимацию и т. Д. Но одна проблема после реализации этого класса MDCCardCollectionCell
, тогда метод didSelect
никогда не вызывается, когда я нажимаю на каждую ячейку.
До того, как все заработало, после того, как я реализовал MDCCardCollectionCell
, возникает проблема.
Как решить эту конкретную проблему?
Вот что я сделал до сих пор
func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
let cell = collectionView.dequeueReusableCell(withReuseIdentifier: cellId, for: indexPath) as! ExploreCellData
cell.exploreData = exploreCategory?.data![indexPath.item]
cell.layer.shouldRasterize = true
cell.layer.rasterizationScale = UIScreen.main.scale
cell.isSelectable = true
cell.cornerRadius = 8
cell.setShadowElevation(ShadowElevation(rawValue: 6), for: .selected)
cell.setShadowColor(UIColor.black, for: .highlighted)
return cell
}
func collectionView(_ collectionView: UICollectionView, didSelectItemAt indexPath: IndexPath) {
if let data = exploreCategory?.data![indexPath.item] {
if let titleImage = data.imageName {
print(titleImage)
// This will push to another view controller after selected
dashboardViewController?.showDetailEachItem(data: titleImage, imageContent: data.titleImage!, imageDesc: data.descImage!)
}
}
}
ExploreCellData
- это пользовательская ячейка, использующая MDCCardCollectionCell
class ExploreCellData: MDCCardCollectionCell {
var exploreData: ExploreDataSection? {
didSet{
if let image = exploreData?.imageName {
viewsProperty.exploreImageView.image = UIImage(named: image)
viewsProperty.exploreNameLabel.text = exploreData?.titleImage
}
}
}
var viewsProperty = ExploreCategoryComponents()
let nameLabelView: UIView = {
let view = UIView()
view.translatesAutoresizingMaskIntoConstraints = false
view.layer.cornerRadius = 5
view.layer.masksToBounds = true
view.backgroundColor = .white
return view
}()
override init(frame: CGRect) {
super.init(frame: frame)
setupConstraint()
}
required init?(coder aDecoder: NSCoder) {
fatalError("init(coder:) has not been implemented")
}
}
extension ExploreCellData {
func setupConstraint() {
addSubview(viewsProperty.cardView)
viewsProperty.cardView.frame = CGRect(x: 0, y: 0, width: frame.width, height: frame.height)
viewsProperty.cardView.addSubview(viewsProperty.exploreImageView)
viewsProperty.cardView.addSubview(nameLabelView)
viewsProperty.cardView.addSubview(viewsProperty.exploreNameLabel)
viewsProperty.exploreImageView.frame = CGRect(x: 5, y: 5, width: frame.width - 10, height: frame.height / 1.5)
// nameLabel.frame = CGRect(x: frame.width / 5, y: imageView.frame.maxY + 2, width: frame.width, height: frame.height / 4)
viewsProperty.exploreNameLabel.topAnchor.constraint(equalTo: viewsProperty.exploreImageView.bottomAnchor).isActive = true
viewsProperty.exploreNameLabel.widthAnchor.constraint(equalTo: self.widthAnchor).isActive = true
viewsProperty.exploreNameLabel.bottomAnchor.constraint(equalTo: viewsProperty.cardView.bottomAnchor).isActive = true
viewsProperty.exploreNameLabel.textAlignment = .center
// viewsProperty.exploreNameLabel.centerYAnchor.constraint(equalTo: nameLabelView.centerYAnchor).isActive = true
// viewsProperty.exploreNameLabel.centerXAnchor.constraint(equalTo: nameLabelView.centerXAnchor).isActive = true
}
}