重新加载UICollectionView时,CABasicAnimation停止

时间:2019-02-14 19:31:20

标签: uicollectionview core-animation cabasicanimation swift4.2 uilongpressgesturerecogni

我需要有关集合视图中问题的帮助。在我的collectionView中,我使用UILongPressGestureRecognizer在项目(图像)中启动CABasicAnimation,但是当我删除项目并重新加载collectionView时,CABasicAnimation会相互交错。 如何防止动画停止? 我需要动画继续,直到用户决定停止为止。

以下是有关我的收藏夹视图的一些信息:

class SentMemesCollectionVC: UICollectionViewController {

//MARK: - PROPERTIES

var memes: [Meme]! {
    return Meme.accessMemes().memes
}

//MARK: - LIFE CYCLE

override func viewDidLoad() {
    super.viewDidLoad()

    let longPressGesture = UILongPressGestureRecognizer(target: self, action: #selector(longTap(_:)))
    self.collectionView.addGestureRecognizer(longPressGesture)
}

@objc func longTap(_手势:UILongPressGestureRecognizer){

    switch gesture.state {
    case .began:
        print("LongPress begin")
        guard let selectedIndexPath = collectionView.indexPathForItem(at: gesture.location(in: collectionView)) else {return}
        collectionView.beginInteractiveMovementForItem(at: selectedIndexPath)
        setEditing(true, animated: true)

    default:
        collectionView.cancelInteractiveMovement()
    }

}

// MARK: - COLLECTIONVIEW DATA SOURCE


//Defini o número de itens em cada seção
override func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
   return memes.count
}


override func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
    let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "gridCell", for: indexPath) as! GridMemeCell
    let meme = memes[indexPath.row]
    cell.prepareGridCell(with: meme)
    cell.delegate = self
    return cell
}

// MARK: - COLLECTIONVIEW DELEGATE
/*
override func collectionView(_ collectionView: UICollectionView, didSelectItemAt indexPath: IndexPath) {
    let memeDetail = storyboard?.instantiateViewController(withIdentifier: "DetailVC") as! MemeDetailVC
    let meme = memes[indexPath.row]
    memeDetail.memeSelected = meme
    Feedback.share.hapticFeedback()

    navigationController?.pushViewController(memeDetail, animated: true)
}
*/
// MARK: - DELETE ITEMS IN COLLECTVIEW


override func setEditing(_ editing: Bool, animated: Bool) {
    super.setEditing(editing, animated: animated)
    Feedback.share.hapticFeedback()

    if let indexPaths = collectionView?.indexPathsForVisibleItems {
        for indexPath in indexPaths {
            if let cell = collectionView?.cellForItem(at: indexPath) as? GridMemeCell {

                if editing {
                    cell.isEditing = editing
                    cell.startAnimate()
                    doneBarButtonItem()

                } else {
                    cell.isEditing = editing
                    cell.stopAnimate()
                    addBarButtonItem()
                }
            }
        }
    }
}

}

这是我的CollectionViewCell

class GridMemeCell: UICollectionViewCell {

//MARK: - OUTLETS

@IBOutlet weak var ivImage: UIImageView!
@IBOutlet weak var deleteMeme: UIVisualEffectView!

//MARK: - PROPERTIES

weak var delegate: GridMemeCellDelegate?

var isAnimate: Bool! = true

//MARK: - METHODS AND COMPUTED PROPERTIES


func prepareGridCell(with meme: Meme) {
    ivImage.image = meme.memeImage

    deleteMeme.layer.cornerRadius = deleteMeme.bounds.width / 2.0
    deleteMeme.layer.masksToBounds = true
    deleteMeme.isHidden = !isEditing
    deleteMeme.contentView.backgroundColor = Theme.current.subViewColor

}

func startAnimate() {
    let shakeAnimation = CABasicAnimation(keyPath: "transform.rotation")
    shakeAnimation.duration = 0.05
    shakeAnimation.repeatCount = 4
    shakeAnimation.autoreverses = true
    shakeAnimation.duration = 0.2
    shakeAnimation.repeatCount = 99999

    let startAngle: Float = (-2) * 3.14159 / 180
    let stopAngle = -startAngle

    shakeAnimation.fromValue = NSNumber(value: startAngle)
    shakeAnimation.toValue = NSNumber(value: 3 * stopAngle)
    shakeAnimation.autoreverses = true
    shakeAnimation.timeOffset = 290 * drand48()

    let layer: CALayer = self.layer
    layer.add(shakeAnimation, forKey: "animate")
    self.deleteMeme.isHidden = false
    isAnimate = true

}

func stopAnimate() {
    let layer: CALayer = self.layer
    layer.removeAnimation(forKey: "animate")
    self.deleteMeme.isHidden = true
    isAnimate = false

}


var isEditing: Bool = false {
    didSet {
        deleteMeme.isHidden = !isEditing

    }
}

@IBAction func btDeleteMeme(_ sender: Any) {
    Feedback.share.hapticFeedback()
    delegate?.deleteCell(cell: self)

}

}

这是我的协议代表单元:

protocol GridMemeCellDelegate: class {
func deleteCell(cell: GridMemeCell)

}

这是我的扩展CollectionView-委托。

extension SentMemesCollectionVC: GridMemeCellDelegate {
func deleteCell(cell: GridMemeCell) {
    if let indexPath = collectionView.indexPath(for: cell) {

        //Apaga o Meme do Array
        Meme.accessMemes().memes.remove(at: indexPath.item)
        collectionView.reloadData()

    }
}

}

0 个答案:

没有答案