检测动画UIImageView上的点击

时间:2017-04-27 07:32:57

标签: ios swift swift3 cakeyframeanimation

我在UIImageView项目上为Swift 3项目使用自定义路径动画。代码大纲如下:

// parentView and other parameters are configured externally
let imageView = UIImageView(image: image)
imageView.isUserInteractionEnabled = true
let gr = UITapGestureRecognizer(target: self, action: #selector(onTap(gesture:)))
parentView.addGestureRecognizer(gr)
parentView.addSubview(imageView)
// Then I set up animation, including:
let animation = CAKeyframeAnimation(keyPath: "position")
// .... eventually ....
imageView.layer.add(animation, forKey: nil)

onTap方法以标准方式声明:

func onTap(gesture:UITapGestureRecognizer) {
    print("ImageView frame is \(self.imageView.layer.visibleRect)")
    print("Gesture occurred at \(gesture.location(in: FloatingImageHandler.parentView))")
}

问题在于,每次调用addGestureRecognizer时,先前的手势识别器都会被覆盖,因此任何检测到的点击始终指向最后添加的图像,并且未准确检测到位置(因此,如果有人在父视图上的任何位置点击,则仍然会触发onTap方法。)

如何在每个imageView的基础上准确检测到点按?由于自定义路径动画要求,我无法使用UIView.animate或其他方法,我也无法创建覆盖透明UIView来覆盖父视图,因为我需要这些" floaters"不要吞下这些事件。

3 个答案:

答案 0 :(得分:1)

目前还不是很清楚你想要实现什么,但我认为你应该将姿势识别器添加到imageView而不是父视图。

所以这个:

parentView.addGestureRecognizer(gr)

应该替换为:

imageView.addGestureRecognizer(gr)

在你的onTap函数中你可能应该这样做:

print("ImageView frame is \(gesture.view.layer.visibleRect)")
print("Gesture occurred at \(gesture.location(in: gesture.view))")

答案 1 :(得分:0)

我认为您可以在imageView功能上查看属于onTap的点击位置。 像这样:

    func ontap(gesture:UITapGestureRecognizer) {
        let point = gesture.location(in: parentView)
        if imageView.layer.frame.contains(point) {
            print("ImageView frame is \(self.imageView.layer.visibleRect)")
            print("Gesture occurred at \(point)")
        }
    }

答案 2 :(得分:0)

由于图层不会更新其框架/位置等,我需要在我写的图像视图子类中添加以下内容(?- a(20). 2 3 5 7 11 13 17 19. ):

FloatingImageView

我还将手势识别器移动到父视图,因此任何时候只有一个GR,并为每个要添加的子视图创建唯一标记。处理程序如下所示:

override func hitTest(_ point: CGPoint, with event: UIEvent?) -> UIView? {
    let pres = self.layer.presentation()!
    let suppt = self.convert(point, to: self.superview!)
    let prespt = self.superview!.layer.convert(suppt, to: pres)
    return super.hitTest(prespt, with: event)
}

其中func onTap(gesture:UITapGestureRecognizer) { let p = gesture.location(in: gesture.view) let v = gesture.view?.hitTest(p, with: nil) if let v = v as? FloatingImageView { print("The tapped view was \(v.tag)") } } FloatingImageView子类。

此方法在iOS 10书籍(以及WWDC)中有所描述,也适用于iOS 9。我仍然在评估基于UIImageView的点击检测,所以如果您能举例说明如何使用UIViewPropertyAnimator来执行上述操作,我会将您的答案标记为正确答案。