Swift中的子类NSApplication

前端之家收集整理的这篇文章主要介绍了Swift中的子类NSApplication前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我创建了NSApplication子类:
class MyApplication: NSApplication {
    override func sendEvent(theEvent: NSEvent) {
        if theEvent.type == NSEventType.KeyUp && (theEvent.modifierFlags & .CommandKeyMask).rawValue != 0 {
            self.keyWindow?.sendEvent(theEvent)
        } else {
            super.sendEvent(theEvent)
        }
    }
}

之后,我将Info.plist中的“Principal class”更改为MyApplication,最后在Main.storyboard的Application Scene中,我也将Application更改为MyApplication.

当我运行应用程序时,我得到以下消息:

Unable to find class: MyApplication,exiting

有人可以帮我弄这个吗?

尝试:
@objc(MyApplication)
class MyApplication: NSApplication {

或者,您必须像这样设置Info.plist.

<key>NSPrincipalClass</key>
<string>YourAppName.MyApplication</string>
        ^^^^^^^^^^^^

没有确切的文件,但this description is corresponding

In order to preserve namespacing when a Swift class is used in Objective-C code,Swift classes are exposed to the Objective-C runtime with their fully qualified names. Therefore,when you work with APIs that operate on the string representation of a Swift class,you must include the fully qualified name of the class. For example,when you create a document–based Mac app,you provide the name of your NSDocument subclass in your app’s Info.plist file. In Swift,you must use the full name of your document subclass,including the module name derived from the name of your app or framework.

this

When you use the @objc(<#name#>) attribute on a Swift class,the class is made available in Objective-C without any namespacing.

猜你在找的Swift相关文章