#selector'的参数没有引用'@objc'方法(快速3)

Argument of #39;#selector#39; does not refer to an #39;@objc#39; method (swift 3)(#selector#39;的参数没有引用#39;@objc#39;方法(快速3))
本文介绍了#selector'的参数没有引用'@objc'方法(快速3)的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在我的SKScene中设置滑动识别,我发现对所有识别器进行硬编码需要时间,而且不是很整洁,所以我决定使用for循环,以及一个包含UISwipeRecognizer作为键、()作为值的字典。问题是,在尝试使用recognizer.addTarget(self, action: #selector(functionForRecognizer[recognizer]!))添加目标时,它在标题中显示错误

代码如下:

class xxxxx: SKScene {

let rightSwipeRecognizer = UISwipeGestureRecognizer()
let leftSwipeRecognizer = UISwipeGestureRecognizer()
let upSwipeRecognizer = UISwipeGestureRecognizer()
let downSwipeRecognizer = UISwipeGestureRecognizer()

var swipeRecognizers: [UISwipeGestureRecognizer] {
    return [rightSwipeRecognizer, leftSwipeRecognizer, upSwipeRecognizer, downSwipeRecognizer]
}

var directionForRecognizer: [UISwipeGestureRecognizer : UISwipeGestureRecognizerDirection] {
    return [
        rightSwipeRecognizer : .right,
        leftSwipeRecognizer : .left,
        upSwipeRecognizer : .up,
        downSwipeRecognizer : .down
    ]
}

func didSwipeRight() {}
func didSwipeLeft() {}
func didSwipeUp() {}
func didSwipeDown() {}

var functionForRecognizer: [UISwipeGestureRecognizer : ()] {
    return [
        rightSwipeRecognizer : didSwipeRight(),
        leftSwipeRecognizer : didSwipeLeft(),
        upSwipeRecognizer : didSwipeUp(),
        downSwipeRecognizer : didSwipeDown()
    ]
}

func setupSwipeRecognizers() {
    for recognizer in swipeRecognizers {
        recognizer.addTarget(self, action: #selector(functionForRecognizer[recognizer]!))
        recognizer.direction = directionForRecognizer[recognizer]!
        self.view?.addGestureRecognizer(recognizer)
    }
}

override func didMove(to view: SKView) {
    super.didMove(to: view)
    setupSwipeRecognizers()
}

} 顺便说一句,我试着在声明函数时放入@objc,但不起作用。此外,我尝试通过移除SKScene的继承并遵循NSObject来将类公开给NSObject,但仍然不起作用。此外,我不能使类符合UIKit类,Cz我需要它作为SKScene,甚至,我尝试将其符合UIView控制器(当然,没有SKScene),但仍然不起作用,

推荐答案

您尝试使用SWIFT的#selector无法完成的操作。而应将Selector类的实例直接插入词典。

您还需要使用@objc进行注释

@objc // This annotation isn't required in Swift 3, but will be in Swift 4
func didSwipeRight() {}

var functionForRecognizer: [UISwipeGestureRecognizer : Selector] {
    return [
        rightSwipeRecognizer : #selector(didSwipeRight)
    ]
}

recognizer.addTarget(self, action: functionForRecognizer[recognizer]))
#selector的详细说明请参阅this answer。总而言之,#selector是SWIFT的编译器构造,它确保存在准确的选择器/方法,包括它应该存在的类。它查看括号中的实际内容,以确定它是否是已知方法,functionForRecognizer[recognizer]不是方法名,它是变量+下标方法调用。

这篇关于#selector'的参数没有引用'@objc'方法(快速3)的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Why local notification is not firing for UNCalendarNotificationTrigger(为什么没有为UNCalendarNotificationTrigger触发本地通知)
Pushing UIViewController above UITabBar(将UIView控制器推送到UITabBar上方)
Dropbox Files.download does not start when number of files in folder is gt; 1000(当文件夹中的文件数为1000时,Dropbox Files.Download不会启动)
appearance().setBackgroundImage Not Working On Custom Class(外观().setBackoundImage在自定义类上不起作用)
Show/Hide barButtonItem(显示/隐藏barButtonItem)
java.lang.IllegalStateException: SimpleTypeImpl should not be created for error type(异常:不应为错误类型创建SimpleTypeImpl)