基于swift4.2常見的全局常量和函數集合(objective-c稱之為宏定義,swift沒有宏這個概念),如有錯誤,請指出,本人立馬做出修改,謝謝
GitHub:https://github.com/WOHANGO/swiftmacro.git 如果滿意,請獻上您的stat
//
// Common.swift
// BSProject
//
// Created by 吳梓杭 on 2018/7/1.
// Copyright © 2018年 吳梓杭. All rights reserved.
//
import UIKit
//擷取沙盒Document路徑
let kDocumentPath = NSSearchPathForDirectoriesInDomains(.documentDirectory, .userDomainMask, true).first
//擷取沙盒Cache路徑
let kCachePath = NSSearchPathForDirectoriesInDomains(.cachesDirectory, .userDomainMask, true).first
//擷取沙盒temp路徑
let kTempPath = NSTemporaryDirectory()
//顔色
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 kColor_nil = UIColor.clear
let kColor_000000 = kHexColor("000000")
let kColor_111111 = kHexColor("111111")
let kColor_222222 = kHexColor("222222")
let kColor_333333 = kHexColor("333333")
let kColor_444444 = kHexColor("444444")
let kColor_555555 = kHexColor("555555")
let kColor_666666 = kHexColor("666666")
let kColor_777777 = kHexColor("777777")
let kColor_888888 = kHexColor("888888")
let kColor_999999 = kHexColor("999999")
let kColor_aaaaaa = kHexColor("aaaaaa")
let kColor_bbbbbb = kHexColor("bbbbbb")
let kColor_cccccc = kHexColor("cccccc")
let kColor_dddddd = kHexColor("dddddd")
let kColor_eeeeee = kHexColor("eeeeee")
let kColor_ffffff = kHexColor("ffffff")
let kColor_ff0000 = kHexColor("ff0000") //大紅
let kColor_00ff00 = kHexColor("00ff00") //大黃
let kColor_0000ff = kHexColor("0000ff") //大藍
//開發的時候列印,但是釋出的時候不列印,使用方法,輸入print(message: "輸入")
func print<T>(message: T, fileName: String = #file, methodName: String = #function, lineNumber: Int = #line) {
#if DEBUG
//擷取目前時間
let now = Date()
// 建立一個日期格式器
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
}
// 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)
}
//擷取螢幕大小
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"]
//目前系統版本号
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)
//擷取目前語言
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)
//适配 350 375 414 568 667 736
func kAutoLayoutWidth(_ width: CGFloat) -> CGFloat {
return width*kUIScreenWidth / 375
}
func kAutoLayoutHeigth(_ height: CGFloat) -> CGFloat {
return height*kUIScreenHeight / 667
}
//機型判斷
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)
//擷取狀态欄、标題欄、導航欄高度
let kUIStatusBarHeight: CGFloat = UIApplication.shared.statusBarFrame.size.height
let kUINavigationBarHeight: CGFloat = kUI_IPHONEX ? 88 : 44
let KUITabBarHeight: CGFloat = kUI_IPHONEX ? 83 : 49
//navigationBarHeight預設高度44 (iPhoneX 88)
//tabBarHeight預設高度49 (iPhoneX 83)
// 注冊通知
func kNOTIFY_ADD(observer: Any, selector: Selector, name: String) {
return NotificationCenter.default.addObserver(observer, selector: selector, name: Notification.Name(rawValue: name), object: nil)
}
// 發送通知
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
//字型 字号
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)
}
/**
字元串是否為空
@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
}
/**
數組是否為空
@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
}
uicolor部分
//
// UIColor+WUIKit.swift
// WUIKit_Demo
//
// Created by 吳梓杭 on 2018/7/5.
// Copyright © 2018年 吳梓杭. All rights reserved.
//
import UIKit
extension UIColor {
/// 傳入一個16進制的字元串,傳回該16進制代表的顔色(預設alpha位1)
///
/// - Parameter hexString: 代表顔色的16進制字元串
/// - Returns: 該16進制表示的顔色
static func colorWith(hexString: String) -> UIColor {
return UIColor.colorWith(hexString: hexString, alpha: 1.0)
}
/// 傳入一個16進制的字元串,傳回該16進制代表的顔色
///
/// - Parameter hexString: 代表顔色的16進制字元串,支援@“#123456”、 @“0X123456”、 @“123456”三種格式
/// - alpha: 顔色的透明度
/// - Returns: 該16進制表示的顔色
static func colorWith(hexString: String, alpha: CGFloat) -> UIColor {
//删除字元串中的空格
var cString = hexString.trimmingCharacters(in: CharacterSet.whitespacesAndNewlines).uppercased()
// strip 0X if it appears
//如果是0x開頭的,那麼截取字元串,字元串從索引為2的位置開始,一直到末尾
if cString.hasPrefix("0X") {
cString = ((cString as NSString).substring(from: 2) as NSString) as String
}
//如果是#開頭的,那麼截取字元串,字元串從索引為1的位置開始,一直到末尾
if cString.hasPrefix("#") {
cString = ((cString as NSString).substring(from: 1) as NSString) as String
}
// String should be 6 or 8 characters
if cString.count < 6 {
print("colorWithHexString is wrong!")
return UIColor.clear
}
// Separate into r, g, b substrings
let rString = (cString as NSString).substring(to: 2)
let gString = ((cString as NSString).substring(from: 2) as NSString).substring(to: 2)
let bString = ((cString as NSString).substring(from: 4) as NSString).substring(to: 2)
var r:CUnsignedInt = 0, g:CUnsignedInt = 0, b:CUnsignedInt = 0;
Scanner(string: rString).scanHexInt32(&r)
Scanner(string: gString).scanHexInt32(&g)
Scanner(string: bString).scanHexInt32(&b)
return UIColor.init(red: CGFloat(r) / 255.0, green: CGFloat(g) / 255.0, blue: CGFloat(b) / 255.0, alpha: alpha)
}
}