Как использовать структуру Swift в Objective C
Просто у меня есть структура, в которой хранятся константы приложения, как показано ниже:
struct Constant {
static let ParseApplicationId = "xxx"
static let ParseClientKey = "xxx"
static var AppGreenColor: UIColor {
return UIColor(hexString: "67B632")
}
}
Эти константы могут использоваться в коде Swift, вызывая, например, Constant.ParseClientKey
. Но в моем коде он также содержит некоторые классы Objective C. Итак, мой вопрос заключается в том, как использовать эти константы в коде Objective C?
Если этот способ объявить константы нехорошо, то каков наилучший способ создания глобальных констант, которые будут использоваться как в коде Swift, так и в Objective C?
Ответы
Ответ 1
Скажем, вы не можете выставить struct
, а глобальные переменные - Objective-C. см. документацию.
На данный момент, IMHO, лучший способ выглядит примерно так:
let ParseApplicationId = "xxx"
let ParseClientKey = "xxx"
let AppGreenColor = UIColor(red: 0.2, green: 0.7, blue: 0.3 alpha: 1.0)
@objc class Constant: NSObject {
private init() {}
class func parseApplicationId() -> String { return ParseApplicationId }
class func parseClientKey() -> String { return ParseClientKey }
class func appGreenColor() -> UIColor { return AppGreenColor }
}
В Objective-C вы можете использовать их следующим образом:
NSString *appklicationId = [Constant parseApplicationId];
NSString *clientKey = [Constant parseClientKey];
UIColor *greenColor = [Constant appGreenColor];
Ответ 2
//Why not create a file something like this:
import UIKit
import Foundation
extension UIColor {
convenience init(hex: Int) {
let components = (
R: CGFloat((hex >> 16) & 0xff) / 255,
G: CGFloat((hex >> 08) & 0xff) / 255,
B: CGFloat((hex >> 00) & 0xff) / 255
)
self.init(red: components.R, green: components.G, blue: components.B, alpha: 1)
}
}
extension CGColor {
class func colorWithHex(hex: Int) -> CGColorRef {
return UIColor(hex: hex).CGColor
}
}
struct Constant {
static let kParseApplicationId = "5678"
static let kParseClientKey = "1234"
static var kAppGreenColor: UIColor { return UIColor(hex:0x67B632) }
static var kTextBlackColor: UIColor { return UIColor(hex:0x000000) }
static var kSomeBgBlueColor: UIColor { return UIColor(hex:0x0000FF) }
static var kLineGrayCGColor: CGColor { return CGColor.colorWithHex(0xCCCCCC) }
static var kLineRedCGColor: CGColor { return CGColor.colorWithHex(0xFF0000) }
}
@objc class Constants: NSObject {
private override init() {}
class func parseApplicationId() -> String { return Constant.kParseApplicationId }
class func parseClientKey() -> String { return Constant.kParseClientKey }
class func appGreenColor() -> UIColor { return Constant.kAppGreenColor }
class func textBlackColor() -> UIColor { return Constant.kTextBlackColor }
class func someBgBlueColor() -> UIColor { return Constant.kSomeBgBlueColor }
class func lineGrayCGColor() -> CGColor { return Constant.kLineGrayCGColor }
class func lineRedCGColor() -> CGColor { return Constant.kLineRedCGColor }
}
//for use in Objective-C files add this when you need to use constants:
//#import "ProjectModuleName-Swift.h"
//Swift usage:
//self.view.backgroundColor = Constant.kAppGreenColor
//Objective-C file:
//self.view.backgroundColor = [Constants appGreenColor];
//This way you can update colors, default text, web service urls for whole app in one place.
//just an idea on this thread.
Ответ 3
Вы должны сделать утверждения let закрытыми, если вы хотите, чтобы другие типы Swift в вашем коде получили доступ к этим константам только через класс:
private let AppGreenColor = UIColor(red: 0.2, green: 0.7, blue: 0.3 alpha: 1.0)
@objc class Constant {
class func appGreenColor() -> UIColor { return AppGreenColor }
}
В Swift вы можете использовать их следующим образом:
UIColor *greenColor = Constant.appGreenColor
Следующая строка больше не будет компилироваться, так как оператор let является закрытым:
UIColor *greenColor = appGreenColor