UICollectionViewDragDelegate не работает

Я успешно реализую UICollectionViewкоторые отображают на экране фиктивные тексты. Все работает нормально, и теперь я добавил функцию перетаскивания, реализующую self.collectionView.dragDelegate = self и UICollectionViewDelegateFlowLayout, но это не работает. Я что-то упустил?

final class XptoComponent: UIView {

    private var titles = ["Xpto 1", "Xpto 2", "Xpto 3", "Xpto 4", "Xpto 5", "Xpto 6", "Xpto 7", "Xpto 8", "Xpto 9"]

    private var collectionView: UICollectionView = {

        let collectionViewLayout = UICollectionViewFlowLayout()
        collectionViewLayout.minimumInteritemSpacing = 0
        collectionViewLayout.minimumLineSpacing = 0
        collectionViewLayout.itemSize = CGSize(width: UIScreen.main.bounds.size.width, height: NumericConstant.ViewCell.height)
        collectionViewLayout.sectionInset = .zero

        let collectionView = UICollectionView(frame: .zero, collectionViewLayout: collectionViewLayout).usingAutoLayout()
        collectionView.registerCell(XptoCollectionViewCell.self)

        return collectionView
    }()

    init() {

        super.init(frame: .zero)

        self.collectionView.dataSource = self
        self.collectionView.delegate = self
        self.collectionView.dragDelegate = self

        self.defineSubviews()
        self.defineSubviewsConstraints()
    }

    private func defineSubviewsConstraints() {

        NSLayoutConstraint.activate([

            self.collectionView.topAnchor.constraint(equalTo: self.topAnchor),
            self.collectionView.leadingAnchor.constraint(equalTo: self.leadingAnchor),
            self.collectionView.trailingAnchor.constraint(equalTo: self.trailingAnchor),
            self.collectionView.bottomAnchor.constraint(equalTo: self.safeAreaLayoutGuide.bottomAnchor)
        ])
    }

    private func defineSubviews() {

        self.addSubview(self.collectionView)
    }

    required init?(coder: NSCoder) {
        fatalError("init(coder:) has not been implemented")
    }
}

extension XptoComponent: UICollectionViewDataSource {

    func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {

        return self.titles.count
    }

    func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {

        let cell = collectionView.dequeueReusableCell(XptoCollectionViewCell.self, for: indexPath)
        cell?.titleLabel.text = self.titles[indexPath.row]

        return cell ?? UICollectionViewCell()
    }
}

extension XptoComponent: UICollectionViewDelegateFlowLayout {

    func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, sizeForItemAt indexPath: IndexPath) -> CGSize {

        return CGSize(width: self.frame.width, height: 100)
    }
}

extension XptoComponent: UICollectionViewDragDelegate {

    func collectionView(_ collectionView: UICollectionView, itemsForBeginning session: UIDragSession, at indexPath: IndexPath) -> [UIDragItem] {

        let title = self.titles[indexPath.item]
        let itemProvider = NSItemProvider(object: title as NSString)
        let dragItem = UIDragItem(itemProvider: itemProvider)

        return [dragItem]
    }
}

2 ответа

Решение

Вам нужно установить эту переменную dragInteractionEnabled к true

 collectionView.dragInteractionEnabled = true

Обязательно верните что-нибудь вcollectionView(_:itemsForBeginning:at:)функция. Возврат пустого массива работает для UITableView, но не для UICollectionView.

Также проверьте, откуда вы возвращаетесьcollectionView(_:canHandle:). Если вы вернете false, это предотвратит перетаскивание.

Другие вопросы по тегам