UICollectionView中的设置顺序属性问题

时间:2019-05-23 00:05:19

标签: ios swift uicollectionview uicollectionviewcell indexpath

我对collectionView有一个奇怪的问题,我有两个原型,第一个应该绘制indexPath.row=0,第二个应该创建四次。 第二个原型包含一个UIView,用于保存使用paintCode应用程序创建的图标和一个文本标签。每个单元格还有四个图标。

override func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
switch indexPath.row {
case 0:
    if let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "cell1", for: indexPath) as? ViewData {
        return cell
    }
case 1,2,3,4:
    if let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "cell2", for: indexPath) as? ViewData {
        switch indexPath.row {
        case 1:
            cell.dataIcon.is1stIcon = true
            cell.title.text = "1"
        case 2:
            cell.dataIcon.is2ndIcon = true
            cell.title.text = "2"
        case 3:
            cell.dataIcon.is3rdIcon = true
            cell.title.text = "3"
        case 4:
            cell.dataIcon.is4thIcon = true
            cell.title.text = "4"
        default:
            break
        }

        return cell
    }
default:
    break
}
return UICollectionViewCell()

}

问题是,所有文本都位于正确的位置(行),但是1stIcon中的indexPath.row=1将显示在indexPath.row=3中,而3rtIcon将显示在indexPath.row=1中显示。 首先,我认为问题可能出在图标上,但是无论我放在这些行中,都有相同的错误倾向。 您对此有何看法? 谢谢

2 个答案:

答案 0 :(得分:0)

问题从单元格出队开始就发生了,您需要像使用它之前重新设置所有内容

  cell.reset()
    switch indexPath.row {
    case 1:
        cell.dataIcon.is1stIcon = true
        cell.title.text = "1"
    case 2:
        cell.dataIcon.is2ndIcon = true
        cell.title.text = "2"
    case 3:
        cell.dataIcon.is3rdIcon = true
        cell.title.text = "3"
    case 4:
        cell.dataIcon.is4thIcon = true
        cell.title.text = "4"
    default:
        break
  }

func reset() {
  // show all of them
  self.dataIcon.is1ndIcon = false
  self.dataIcon.is2ndIcon = false
  self.dataIcon.is3ndIcon = false
  self.dataIcon.is4ndIcon = false
}

答案 1 :(得分:0)

我认为您应该使用[collectionViewLayout]委派方法。

func collectionView(_ collectionView: UICollectionView,
                    layout collectionViewLayout: UICollectionViewLayout,
                    sizeForItemAt indexPath: IndexPath) -> CGSize {
    // Specify the cell frame of row=1
    if indexPath.row == 1 {
        return CGSize(width: collectionView.bounds.width - 20, height: collectionView.bounds.height/4-5)
    }

    // Other...
    return CGSize(width: (collectionView.bounds.width-40)/3 - 1, height: collectionView.bounds.width/3-5)

}