CollectionViewCell无法在捏手势中正常工作

问题描述 投票:0回答:1

我正在使用CollectionView和连接到CVCell的捏手势。我在单元格中有一个图像,“捏手势”在图像中放大和缩小。我的问题是Pinch Gesture仅适用于偶数行,不适用于奇数行。我的意思是,对于第一个单元格,我无法缩放图片,可以在第二个单元格中放大图片,对于第三个单元格不能缩放,对于第四个单元格则不能,这样就可以继续进行。我找不到合乎逻辑的解释。所以也许您可以看到我的想念。提前致谢。我的代码在这里:

@IBAction func handlePinch(recognizer : UIPinchGestureRecognizer) {
    if let view = recognizer.view {
        view.transform = CGAffineTransformScale(view.transform,
            recognizer.scale, recognizer.scale)
        recognizer.scale = 1
    }
}

@IBOutlet weak var collectionView: UICollectionView!
override func viewDidLoad() {
    super.viewDidLoad()
    var b = UIBarButtonItem(barButtonSystemItem: .Bookmarks, target: self, action: "barButton")
    self.navigationItem.rightBarButtonItem = b
    var ItemIndex = NSIndexPath(forItem: catchNumber, inSection: 0)
    self.collectionView?.scrollToItemAtIndexPath(ItemIndex, atScrollPosition: UICollectionViewScrollPosition.CenteredHorizontally, animated: false)
}

override func didReceiveMemoryWarning() {
    super.didReceiveMemoryWarning()

}

func barButton(){
    let alert = UIAlertController(title: "Select an option", message: " ", preferredStyle: UIAlertControllerStyle.ActionSheet)
    let shareButton = UIAlertAction(title: "Share", style: UIAlertActionStyle.Default) { (alert) -> Void in
        let content = FBSDKSharePhotoContent()
        let photo : FBSDKSharePhoto = FBSDKSharePhoto()
        photo.image = self.image
        photo.userGenerated = true
        content.photos = [photo]
        FBSDKMessageDialog.showWithContent(content, delegate:nil)
    }
    let saveButton = UIAlertAction(title: "Save", style: UIAlertActionStyle.Default) { (alert) -> Void in
        UIImageWriteToSavedPhotosAlbum(self.image, nil, nil, nil)
    }
    let deleteButton = UIAlertAction(title: "Delete", style: UIAlertActionStyle.Default) { (alert) -> Void in
        var tmp = self.catchPictures[self.catchNumber].componentsSeparatedByString("_")
        self.idDelete = tmp[1]
        let graphRequest : FBSDKGraphRequest = FBSDKGraphRequest(graphPath: "/\(self.idDelete)", parameters: nil , HTTPMethod: "DELETE")
        graphRequest.startWithCompletionHandler({ (connection, result, error) -> Void in
            if (error == nil){
                self.navigationController?.popViewControllerAnimated(true)
            }else{
                let alertController = UIAlertController(title: "Delete Error", message:
                    "An error occured while deleting photo", preferredStyle: UIAlertControllerStyle.Alert)
                alertController.addAction(UIAlertAction(title: "OK", style: UIAlertActionStyle.Default,handler: nil))

                self.presentViewController(alertController, animated: true, completion: nil)
            }

        })
    }
    let cancelButton = UIAlertAction(title: "Cancel", style: UIAlertActionStyle.Cancel) { (alert) -> Void in
        println("Cancel Pressed")
    }
    alert.addAction(shareButton)
    alert.addAction(saveButton)
    alert.addAction(deleteButton)
    alert.addAction(cancelButton)
    self.presentViewController(alert, animated: true, completion: nil)
}

func collectionView(collectionView: UICollectionView, numberOfSectionInCollectionView section: Int) -> Int {
    return 1
}

func collectionView(collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
    return catchPictures.count

}

func collectionView(collectionView: UICollectionView, cellForItemAtIndexPath indexPath: NSIndexPath) -> UICollectionViewCell {
    var cell = collectionView.dequeueReusableCellWithReuseIdentifier("PhotoCell", forIndexPath: indexPath) as! UICollectionViewCell
    let a:UIImageView = cell.contentView.viewWithTag(1) as! UIImageView
    dispatch_async(dispatch_get_main_queue(),{
        var urlString: NSString = self.catchPictures[indexPath.row] as NSString
        var imgURL: NSURL = NSURL(string: urlString as String)!
        var request: NSURLRequest = NSURLRequest(URL: imgURL)
        var urlConnection: NSURLConnection = NSURLConnection(request: request, delegate: self)!
        NSURLConnection.sendAsynchronousRequest(request, queue: NSOperationQueue.mainQueue(), completionHandler: {(response: NSURLResponse!,data: NSData!,error: NSError!) -> Void in
            if !(error != nil) {
                var image = UIImage(data: data)
                a.image = image
                self.image = a.image
            }})

        self.flowLayout.minimumInteritemSpacing = 0.0
        self.flowLayout.minimumLineSpacing = 0.0
        self.flowLayout.itemSize = CGSizeMake(self.view.frame.width, 350)
        self.flowLayout.scrollDirection = UICollectionViewScrollDirection.Horizontal
        self.collectionView.setCollectionViewLayout(self.flowLayout, animated: true)
    })
    self.catchNumber = indexPath.row
    return cell
}
ios swift gesture pinch
1个回答
0
投票

[不,没有自定义CVCell,这是我写CVCell作为CollectionViewCell的简短含义的我的错误,这在我没有使用任何自定义集合视图单元的代码中可以看到;)造成误解的原因

© www.soinside.com 2019 - 2024. All rights reserved.