Swift常用的全局常量和函數(shù)(OC宏定義)

// 那么在Swift中如何對常用的工具方法進(jìn)行定義呢? Swift中不支持#define語法,只能依賴Swift自身的特性來實(shí)現(xiàn):

在OC中我們通常使用宏定義來實(shí)現(xiàn)全局常量的表示,而swift中宏定義這個(gè)說法已經(jīng)取締了,一般的有如下幾種方式: 1. 常量 2. 全局函數(shù) 3. 計(jì)算屬性 4. 閉包類型的常量

// MARK:- 日志打印

//開發(fā)的時(shí)候打印,但是發(fā)布的時(shí)候不打印,使用方法,輸入 print(message: "輸入")

  func print<T>(message: T, fileName: String = #file, methodName: String = #function, lineNumber: Int = #line) {
      #if DEBUG
      //獲取當(dāng)前時(shí)間
      let now = Date()
      // 創(chuàng)建一個(gè)日期格式器
      let dformatter = DateFormatter()
      dformatter.dateFormat = "yyyy-MM-dd HH:mm:ss.SSS"
      // 要把路徑最后的字符串截取出來
      let lastName = ((fileName as NSString).pathComponents.last!)
      print("\(dformatter.string(from: now)) [\(lastName)][第\(lineNumber)行] \n\t\t \(message)")
      #endif
  }

// MARK:- 沙盒相關(guān)

//獲取沙盒Document路徑
let kDocumentPath = NSSearchPathForDirectoriesInDomains(.documentDirectory, .userDomainMask, true).first
//獲取沙盒Cache路徑
let kCachePath = NSSearchPathForDirectoriesInDomains(.cachesDirectory, .userDomainMask, true).first
//獲取沙盒temp路徑
let kTempPath = NSTemporaryDirectory()

// MARK:- UserDefaults 操作

    let kUserDefaults = UserDefaults.standard
    func kUserDefaultsRead(_ KeyStr: String) -> String {
        return kUserDefaults.string(forKey: KeyStr)!
    }
    func kUserDefaultsWrite(_ obj: Any, _ KeyStr: String) {
        kUserDefaults.set(obj, forKey: KeyStr)
    }
    func kUserValue(_ A: String) -> Any? {
        return kUserDefaults.value(forKey: A)
    }

// MARK:- 顏色

func kRGBAColor(_ r: CGFloat,_ g: CGFloat,_ b: CGFloat,_ a: CGFloat) -> UIColor {
    return UIColor.init(red: r, green: g, blue: b, alpha: a)
}
func kRGBColor(_ r: CGFloat,_ g: CGFloat,_ b: CGFloat) -> UIColor {
    return UIColor.init(red: r, green: g, blue: b, alpha: 1.0)
}
func kHexColorA(_ HexString: String,_ a: CGFloat) ->UIColor {
    return UIColor.colorWith(hexString: HexString, alpha: a)
}
func kHexColor(_ HexString: String) ->UIColor {
    return UIColor.colorWith(hexString: HexString)
}
// 通用顏色值

let kBackGroundColor = kHexColor("f0f0f0")

//字體 字號

func kFontSize(_ a: CGFloat) -> UIFont {
    return UIFont.systemFont(ofSize: a)
}
func kFontBoldSize(_ a: CGFloat) -> UIFont {
    return UIFont.boldSystemFont(ofSize: a)
}
func kFontForIPhone5or6Size(_ a: CGFloat, _ b: CGFloat) -> UIFont {
    return kUI_IPHONE5 ? kFontSize(a) : kFontSize(b)
}

// MARK:- 獲取屏幕大小

let kUIScreenSize = UIScreen.main.responds(to: #selector(getter: UIScreen.nativeBounds)) ? CGSize(width: UIScreen.main.nativeBounds.size.width / UIScreen.main.nativeScale, height: UIScreen.main.nativeBounds.size.height / UIScreen.main.nativeScale) : UIScreen.main.bounds.size
let kUIScreenWidth = kUIScreenSize.width
let kUIScreenHeight = kUIScreenSize.height
let kUIScreenBounds = UIScreen.main.bounds

//APP版本號

let kAppVersion = Bundle.main.infoDictionary?["CFBundleShortVersionString"]
//當(dāng)前系統(tǒng)版本號
let kVersion = (UIDevice.current.systemVersion as NSString).floatValue
//檢測用戶版本號
let kiOS12 = (kVersion >= 12.0)
let kiOS11 = (kVersion >= 11.0 && kVersion < 12.0)
let kiOS10 = (kVersion >= 10.0 && kVersion < 11.0)
let kiOS9 = (kVersion >= 9.0 && kVersion < 10.0)
let kiOS8 = (kVersion >= 8.0 && kVersion < 9.0)
let kiOS12Later = (kVersion >= 12.0)
let kiOS11Later = (kVersion >= 11.0)
let kiOS10Later = (kVersion >= 10.0)
let kiOS9Later = (kVersion >= 9.0)
let kiOS8Later = (kVersion >= 8.0)

//獲取當(dāng)前語言

let kAppCurrentLanguage = Locale.preferredLanguages[0]
//判斷是否為iPhone
let kDeviceIsiPhone = (UI_USER_INTERFACE_IDIOM() == .phone)
//判斷是否為iPad
let kDeviceIsiPad = (UI_USER_INTERFACE_IDIOM() == .pad)

//判斷 iPhone 的屏幕尺寸

let kSCREEN_MAX_LENGTH = max(kUIScreenWidth, kUIScreenHeight)
let kSCREEN_MIN_LENGTH = min(kUIScreenWidth, kUIScreenHeight)

//獲取狀態(tài)欄、標(biāo)題欄、導(dǎo)航欄高度

let kUIStatusBarHeight: CGFloat = UIApplication.shared.statusBarFrame.size.height
let kUINavigationBarHeight: CGFloat =  kUI_IPHONEX ? 88 : 44
let KUITabBarHeight: CGFloat = kUI_IPHONEX ? 83 : 49
//navigationBarHeight默認(rèn)高度44 (iPhoneX 88)
//tabBarHeight默認(rèn)高度49     (iPhoneX 83)

//適配 350 375 414       568 667 736
func kAutoLayoutWidth(_ width: CGFloat) -> CGFloat {
    return width*kUIScreenWidth / 375
}
func kAutoLayoutHeigth(_ height: CGFloat) -> CGFloat {
    return height*kUIScreenHeight / 667
}

//機(jī)型判斷

let kUI_IPHONE = (UIDevice.current.userInterfaceIdiom == .phone)
let kUI_IPHONE5 = (kUI_IPHONE && kSCREEN_MAX_LENGTH == 568.0)
let kUI_IPHONE6 = (kUI_IPHONE && kSCREEN_MAX_LENGTH == 667.0)
let kUI_IPHONEPLUS = (kUI_IPHONE && kSCREEN_MAX_LENGTH == 736.0)
let kUI_IPHONEX = (kUI_IPHONE && kSCREEN_MAX_LENGTH > 780.0)

// 注冊通知

func kNOTIFY_ADD(observer: Any, selector: Selector, name: String) {
    return NotificationCenter.default.addObserver(observer, selector: selector, name: Notification.Name(rawValue: name), object: nil)
}
// 發(fā)送通知
func kNOTIFY_POST(name: String, object: Any) {
    return NotificationCenter.default.post(name: Notification.Name(rawValue: name), object: object)
}
// 移除通知
func kNOTIFY_REMOVE(observer: Any, name: String) {
    return NotificationCenter.default.removeObserver(observer, name: Notification.Name(rawValue: name), object: nil)
}

//代碼縮寫

let kApplication = UIApplication.shared
let kAPPKeyWindow = kApplication.keyWindow
let kAppDelegate = kApplication.delegate
let kAppNotificationCenter = NotificationCenter.default
let kAppRootViewController = kAppDelegate?.window??.rootViewController

/**
字符串是否為空
@param str NSString 類型 和 子類
@return BOOL類型 true or false
*/

func kStringIsEmpty(_ str: String!) -> Bool {
    if str.isEmpty {
        return true
    }
    if str == nil {
        return true
    }
    if str.count < 1 {
        return true
    }
    if str == "(null)" {
        return true
    }
    if str == "null" {
        return true
    }
    return false
}

// 字符串判空 如果為空返回@“”

func kStringNullToempty(_ str: String) -> String {
    let resutl = kStringIsEmpty(str) ? "" : str
    return resutl
}
func kStringNullToReplaceStr(_ str: String,_ replaceStr: String) -> String {
    let resutl = kStringIsEmpty(str) ? replaceStr : str
    return resutl
}

/**
數(shù)組是否為空
@param array NSArray 類型 和 子類
@return BOOL類型 true or false
*/

func kArrayIsEmpty(_ array: [String]) -> Bool {
    let str: String! = array.joined(separator: "")
    if str == nil {
        return true
    }
    if str == "(null)" {
        return true
    }
    if array.count == 0 {
        return true
    }
    if array.isEmpty {
        return true
    }
    return false
}

/**
字典是否為空
@param dic NSDictionary 類型 和子類
@return BOOL類型 true or false
*/

func kDictIsEmpty(_ dict: NSDictionary) -> Bool {
    let str: String! = "\(dict)"
    if str == nil {
        return true
    }
    if str == "(null)" {
        return true
    }
    if dict .isKind(of: NSNull.self) {
        return true
    }
    if dict.allKeys.count == 0 {
        return true
    }
    return false
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容