簡體   English   中英

MDCCardCollectionCell不調用didSelect方法-Swift

[英]MDCCardCollectionCell doesn't call didSelect method - swift

我想定制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
  }

}

在集合視圖中didSelect嘗試調用類類型

   let cell = collectionView.cell(indexPath.row) as? ExploreCellData
    if let data = cell.exploreCatagory.......

另外,請嘗試設置單元格isSelectable這是一個網站,如果這些按鈕不起作用,它將提供幫助: https : //material.io/develop/ios/components/cards/api-docs/Classes/MDCCardCollectionCell.html#/c : objc (cs)MDCCardCollectionCell(py)可選

暫無
暫無

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

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