[英]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.