我想使用最初用 Swift 编写的类
按照我应该在网上找到的说明:
- 将 swift 代码添加到目标
- 在我想要使用 swift 中定义的类的
.m
文件中添加#import "projectName-swift.h"
header 。
这样做之后,我尝试使用用 swift 代码定义的类,如下所示:
JPEG *jpeg = nil;
但是编译器遵守使用未声明的标识符“JPEG”
这是发生的事情:
这是 JPEG 类:
import Foundation
import MobileCoreServices
import ImageIO
class JPEG {
fileprivate let kFigAppleMakerNote_AssetIdentifier = "17"
fileprivate let path : String
init(path : String) {
self.path = path
}
func read() -> String? {
guard let makerNote = metadata()?.object(forKey: kCGImagePropertyMakerAppleDictionary) as! NSDictionary? else {
return nil
}
return makerNote.object(forKey: kFigAppleMakerNote_AssetIdentifier) as! String?
}
func write(_ dest : String, assetIdentifier : String) {
guard let dest = CGImageDestinationCreateWithURL(URL(fileURLWithPath: dest) as CFURL, kUTTypeJPEG, 1, nil)
else { return }
defer { CGImageDestinationFinalize(dest) }
guard let imageSource = self.imageSource() else { return }
guard let metadata = self.metadata()?.mutableCopy() as! NSMutableDictionary! else { return }
let makerNote = NSMutableDictionary()
makerNote.setObject(assetIdentifier, forKey: kFigAppleMakerNote_AssetIdentifier as NSCopying)
metadata.setObject(makerNote, forKey: kCGImagePropertyMakerAppleDictionary as String as String as NSCopying)
CGImageDestinationAddImageFromSource(dest, imageSource, 0, metadata)
}
fileprivate func metadata() -> NSDictionary? {
return self.imageSource().flatMap {
CGImageSourceCopyPropertiesAtIndex($0, 0, nil) as NSDictionary?
}
}
fileprivate func imageSource() -> CGImageSource? {
return self.data().flatMap {
CGImageSourceCreateWithData($0 as CFData, nil)
}
}
fileprivate func data() -> Data? {
return (try? Data(contentsOf: URL(fileURLWithPath: path)))
}
}
发生了什么?如何做到这一点?
最佳答案
我最终通过使 NSObject
的 JPEG
swift 类子类实现了这项工作,不知道为什么,但它现在可以工作了。
class JPEG:NSObject {
...
}
关于ios - 将 swift 代码移植到 Objective-C 项目后使用未声明的标识符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47545428/