我有视图,我想在其中执行向右滑动手势.不幸的是我收到错误 EXC_BAD_ACCESS.有人知道这里有什么问题吗?请看下面的代码. extension UIView { func addGestureRecognizerWithAction(nizer: UIGestureRecognizer,
EXC_BAD_ACCESS.有人知道这里有什么问题吗?请看下面的代码.
extension UIView {
func addGestureRecognizerWithAction(nizer: UIGestureRecognizer, action:() -> ()) {
class Invoker {
var action:() -> ()
init(action:() -> ()) {
self.action = action
}
func invokeTarget(nizer: UIGestureRecognizer) {
self.action()
println("Hi from invoker")
}
}
addGestureRecognizer(nizer)
nizer.addTarget(Invoker(action), action: "invokeTarget:")
}
}
class BugView: UIView {
override func awakeFromNib() {
super.awakeFromNib()
var swipeRight = UISwipeGestureRecognizer()
swipeRight.direction = UISwipeGestureRecognizerDirection.Right
self.addGestureRecognizerWithAction(swipeRight) {
println("Hi from the gesture closure")
}
}
}
最后返回true是对的.在他上面的回答中,他指出我正确的方向,建议让Invoker成为NSObject的子类.
但这不是我在代码中唯一的错误.我发现当滑动发生时,旨在处理事件的Invoker对象已经从内存中消失了.我认为关闭它的提法并没有像它应该的那样被捕获.现在我想出了另一种实现此功能的方法,我想与您分享:
class UIGestureRecognizerWithClosure: NSObject { // must subclass NSObject otherwise error: "class does not implement methodSignatureForSelector: -- " !!
var closure:() -> ()
init(view:UIView, nizer: UIGestureRecognizer, closure:() -> ()) {
self.closure = closure
super.init()
view.addGestureRecognizer(nizer)
nizer.addTarget(self, action: "invokeTarget:")
}
func invokeTarget(nizer: UIGestureRecognizer) {
self.closure()
}
}
此代码段显示了如何使用代码:
var swipeRight = UISwipeGestureRecognizer()
swipeRight.direction = UISwipeGestureRecognizerDirection.Right
// swipeWrapper has to be defined as a property: var swipeWrapper:UIGestureRecognizerWithClosure?
// -> this is needed in order to keep the object alive till the swipe event occurs
swipeWrapper = UIGestureRecognizerWithClosure(view: self, nizer:swipeRight) {
println("Hi from the gesture closure")
}
