//--------------------------
//MARK:SamLi 判斷當前的iPhone裝置/模擬器/系統版本
//判斷是否為iPhone
#define IS_IPHONE (UI_USER_INTERFACE_IDIOM() == UIUserInterfaceIdiomPhone)
//判斷是否為iPad
#define IS_IPAD (UI_USER_INTERFACE_IDIOM() == UIUserInterfaceIdiomPad)
//判斷是否為ipod
#define IS_IPOD ([[[UIDevice currentDevice] model] isEqualToString:@"iPod touch"])
// 判斷是否為 iPhone 5SE
#define iPhone5SE [[UIScreen mainScreen] bounds].size.width == 320.0f && [[UIScreen mainScreen] bounds].size.height == 568.0f
// 判斷是否為iPhone 6/6s
#define iPhone6_6s [[UIScreen mainScreen] bounds].size.width == 375.0f && [[UIScreen mainScreen] bounds].size.height == 667.0f
// 判斷是否為iPhone 6Plus/6sPlus
#define iPhone6Plus_6sPlus [[UIScreen mainScreen] bounds].size.width == 414.0f && [[UIScreen mainScreen] bounds].size.height == 736.0f
//獲取系統版本
#define IOS_SYSTEM_VERSION [[[UIDevice currentDevice] systemVersion] floatValue]
//判斷 iOS 8 或更高的系統版本
#define IOS_VERSION_8_OR_LATER (([[[UIDevice currentDevice] systemVersion] floatValue] >=8.0)? (YES):(NO))
//判斷是真機還是模擬器
#if TARGET_OS_IPHONE
//iPhone Device
#endif
#if TARGET_IPHONE_SIMULATOR
//iPhone Simulator
#endif
//MARK: 獲取螢幕(或者view) frame
//獲取view的frame(不建議使用)
#define kGetViewWidth(view) view.frame.size.width
#define kGetViewHeight(view) view.frame.size.height
#define kGetViewX(view) view.frame.origin.x
#define kGetViewY(view) view.frame.origin.y
//需要橫屏或者豎屏,獲取螢幕寬度與高度
#if __IPHONE_OS_VERSION_MAX_ALLOWED >= 80000 // 當前Xcode支援iOS8及以上
#define SCREEN_WIDTH ([[UIScreen mainScreen] respondsToSelector:@selector(nativeBounds)]?[UIScreen mainScreen].nativeBounds.size.width/[UIScreen mainScreen].nativeScale:[UIScreen mainScreen].bounds.size.width)
#define SCREENH_HEIGHT ([[UIScreen mainScreen] respondsToSelector:@selector(nativeBounds)]?[UIScreen mainScreen].nativeBounds.size.height/[UIScreen mainScreen].nativeScale:[UIScreen mainScreen].bounds.size.height)
#define SCREEN_SIZE ([[UIScreen mainScreen] respondsToSelector:@selector(nativeBounds)]?CGSizeMake([UIScreen mainScreen].nativeBounds.size.width/[UIScreen mainScreen].nativeScale,[UIScreen mainScreen].nativeBounds.size.height/[UIScreen mainScreen].nativeScale):[UIScreen mainScreen].bounds.size)
#else
#define SCREEN_WIDTH [UIScreen mainScreen].bounds.size.width
#define SCREENH_HEIGHT [UIScreen mainScreen].bounds.size.height
#define SCREEN_SIZE [UIScreen mainScreen].bounds.size
#endif
//MARK: ---View---
//MARK: 獲取圖片資源
#define kGetImage(imageName) [UIImage imageNamed:[NSString stringWithFormat:@"%@",imageName]
//MARK: SamLi 顏色設定
//設定隨機顏色
#define SLRandomColor [UIColor colorWithRed:arc4random_uniform(256)/255.0 green:arc4random_uniform(256)/255.0 blue:arc4random_uniform(256)/255.0 alpha:1.0]
//設定RGB顏色/設定RGBA顏色
#define SLRGBColor(r, g, b) [UIColor colorWithRed:(r)/255.0 green:(g)/255.0 blue:(b)/255.0 alpha:1.0]
#define SLRGBAColor(r, g, b, a) [UIColor colorWithRed:(r)/255.0 green:(r)/255.0 blue:(r)/255.0 alpha:a]
// clear背景顏色
#define SLClearColor [UIColor clearColor]
//MARK: 設定 view 圓角和邊框
#define SLViewBorderRadius(View, Radius, Width, Color)\
\
[View.layer setCornerRadius:(Radius)];\
[View.layer setMasksToBounds:YES];\
[View.layer setBorderWidth:(Width)];\
[View.layer setBorderColor:[Color CGColor]]
//MARK: ------
//MARK: 獲取通知中心
#define SLNotificationCenter [NSNotificationCenter defaultCenter]
//MARK: 弱引用/強引用
#define SLWeakSelf(type) __weak typeof(type) weak##type = type;
#define SLStrongSelf(type) __strong typeof(type) type = weak##type;
//MARK: 由角度轉換弧度 由弧度轉換角度
#define SLDegreesToRadian(x) (M_PI * (x) / 180.0)
#define SLRadianToDegrees(radian) (radian*180.0)/(M_PI)
//MARK: 獲取當前語言
#define SLCurrentLanguage ([[NSLocale preferredLanguages] objectAtIndex:0])
//MARK: ------
//MARK: SamLi 使用 ARC 和 MRC
#if __has_feature(objc_arc)
// ARC code
#else
// MRC code
#endif
//MARK: Debug/Realse 中的NSLog
#ifdef DEBUG
#define SLLog(...) NSLog(@"%s 第%d行 \n %@\n\n",__func__,__LINE__,[NSString stringWithFormat:__VA_ARGS__])
#else
#define SLLog(...)
#endif
//MARK: 判斷Target區分,書寫程式碼
//Build Settings ->Preprocessor Macros ->Target_Name
#ifdef Target_Name
// 此target版本新增的程式碼
#endif
#ifndef Target_Name
// 除去此target版本 ,其他target新增使用的程式碼
#endif
//MARK: ---沙盒目錄 ---
//獲取temp
#define kPathTemp NSTemporaryDirectory()
//獲取沙盒 Document
#define kPathDocument [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) firstObject]
//獲取沙盒 Cache
#define kPathCache [NSSearchPathForDirectoriesInDomains(NSCachesDirectory, NSUserDomainMask, YES) firstObject]
//MARK: ---GCD ---
//GCD - 一次性執行
#define kDISPATCH_ONCE_BLOCK(onceBlock) static dispatch_once_t onceToken; dispatch_once(&onceToken, onceBlock);
//GCD - 在Main執行緒上執行
#define kDISPATCH_MAIN_THREAD(mainQueueBlock) dispatch_async(dispatch_get_main_queue(), mainQueueBlock);
//GCD - 開啟非同步執行緒
#define kDISPATCH_GLOBAL_QUEUE_DEFAULT(globalQueueBlock) dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), globalQueueBlocl);
//-----------------------------------
複製程式碼
iOS常用巨集定義
相關文章
- iOS-日常開發常用巨集定義iOS
- iOS 常用巨集定義大全iOS
- ios開發的巨集定義iOS
- iOS 通用巨集定義 高效全域性巨集彙總iOS
- iOS 官方巨集定義 - “引入”、“廢棄”iOS
- iOS開發:pch檔案中的巨集定義iOS
- iOS開發常用的巨集iOS
- iOS開發技巧:應用巨集定義使用字型iOS
- C語言(巨集定義)C語言
- Swift 裡的巨集定義Swift
- C++巨集定義#defineC++
- 使用ant巨集定義任務
- VC++實用巨集定義C++
- iOS開發常用巨集,持續更新中iOS
- object-c 常用判斷null的巨集定義,如果是null直接返回@””ObjectNull
- 0x03. 使用巨集定義事件事件
- C++中巨集定義#define的用法C++
- c/c++標準預定義巨集C++
- 059.Define 巨集定義的巢狀巢狀
- define巨集定義和const常量定義之間的區別
- pch檔案的使用, 標頭檔案使用, 常量(const)的定義,以及一些常用的巨集定義
- Visual C++ MFC 中常用巨集的含義C++
- 【iOS】定義@property時常用的修飾詞介紹iOS
- c 語言中巨集定義和定義全域性變數的區別變數
- 【C進階】21、巨集定義與使用分析
- 跨平臺開發,各種巨集的定義
- 巨集定義和列舉型別的區別型別
- 一個C++巨集定義與列舉定義重複的編譯錯誤C++編譯
- gcc編譯階段列印巨集定義的內容GC編譯
- 有關C語言的知識---巨集定義用法C語言
- 記憶體對齊巨集定義的簡明解釋記憶體
- C語言中的標頭檔案中的巨集定義C語言
- C 語言巨集定義 #define 的理解與資料整理
- C語言巨集定義##連線符和#符的使用C語言
- C語言巨集定義中#define中的井號#的使用C語言
- 教你看懂C++類庫函式定義之一---HRESULT 巨集C++函式
- libev中ev_loop結構體中巨集定義的理解OOP結構體
- C/C++語言巨集定義##連線符和符#的使用C++