Swift 開發的工具類,主要是提供正則表達式及其它類的擴展(新增長)

Swift 開發的工具類,主要是提供正則表達式及其它類的擴展

直接看GitHub源碼javascript

新增長一些方法的擴展。如:UIView的擴展,富文本的擴展,UIColor的擴展,線程安全使用的擴展

3.UIView的一些擴展

主要是方便直接對視圖控件x,y等等一系列的操做

這個比較簡單,不作介紹,主要是 set,get,集成後直接用就行

extension UIView {

    var x: CGFloat {
        get {
            return frame.origin.x
        }
        set {
            frame = CGRect(x: newValue, y: frame.origin.y, width: frame.width, height: frame.height)
        }
    }
    ........................複製代碼

4.線程安全操做

在Oc中爲了防止多線程中對某些資源的安全訪問 引用了

@synchronized的操做,更多的關於多線程的知識 點我,這裏大量篇幅的描述,會使你獲得更多的收穫。這裏不作陳述java

在Swift中已經移除了synchronized 的使用,相應的 咱們能夠直接使用:

objc_sync_enter
///資源的操做
objc_sync_exitgit

結合閉包的使用能夠直接這樣使用

public func synchronized(_ lock: AnyObject, closure: () -> ()) {
    objc_sync_enter(lock)
    closure()
    objc_sync_exit(lock)
}複製代碼

相應的執行的時候你能夠這樣:

var test = 0
synchronized(test as AnyObject) {
    test = 1     // test 在該做用域不會被其餘線程改變
    print(test)
}
/// 或者這樣
synchronized(test as AnyObject, closure: {
    print(test)  // test 在該做用域不會被其餘線程改變
})複製代碼

這樣你就能夠愉快的使用了

5.對UIColor的擴展

都知道Xcode在8.0之後能夠直接在代碼中使用顏色編輯器,圖片預覽。這樣大大的節省了咱們的開發效率

而在於有時候的習慣的使用上來講,可能或多或少還有用代碼來操做的,這裏帶給你們在使用代碼的時候的一些方便

有時候在開發的過程當中UI給的標註是 0xCE0755 這樣的顏色標註,那麼咱們有時候就須要轉換,固然在顏色編輯器裏面是能夠直接使用的。

轉換以下:github

public extension UIColor {

    /// Init color without divide 255.0
    ///
    /// - Parameters:
    /// - r: (0 ~ 255) red
    /// - g: (0 ~ 255) green
    /// - b: (0 ~ 255) blue
    /// - a: (0 ~ 1) alpha
    convenience init(r: Int, g: Int, b: Int, a: CGFloat) {
        self.init(red: CGFloat(r) / 255, green: CGFloat(g) / 255, blue: CGFloat(b) / 255, alpha: a)
    }

    /// Init color without divide 255.0
    ///
    /// - Parameters:
    /// - r: (0 ~ 255) red
    /// - g: (0 ~ 255) green
    /// - b: (0 ~ 1) alpha
    convenience init(r: Int, g: Int, b: Int) {
        self.init(r: r, g: g, b: b, a: 1)
    }

    /// Init color with hex code
    ///
    /// - Parameter hex: hex code (eg. 0x00eeee)
    convenience init(hex: Int) {
        self.init(r: (hex & 0xff0000) >> 16, g: (hex & 0xff00) >> 8, b: (hex & 0xff), a: 1)
    }

}複製代碼

這裏要說的是主要原理就是: 先經過&運算,取得相應的顏色位,而後經過左移相應的位數來進行換算。這裏就很少說了。傳送門

6.富文本的一些操做,工程中很是清楚的介紹了使用,這裏不作陳述了。

科學計數法轉換
人民幣的金額轉換

7.對String的擴展,進行截取,插入操做

extension String {
    /// 截取第一個到第任意位置
    ///
    /// - Parameter end: 結束的位值
    /// - Returns: 截取後的字符串
    func stringCut(end: Int) ->String{
        printLogDebug(self.characters.count)
        if !(end < characters.count) { return "截取超出範圍" }
        let sInde = index(startIndex, offsetBy: end)
        return substring(to: sInde)
    }

    /// 截取人任意位置到結束
    ///
    /// - Parameter end:
    /// - Returns: 截取後的字符串
    func stringCutToEnd(star: Int) -> String {
        if !(star < characters.count) { return "截取超出範圍" }
        let sRang = index(startIndex, offsetBy: star)..<endIndex
        return substring(with: sRang)
    }

    /// 字符串任意位置插入
    ///
    /// - Parameters:
    /// - content: 插入內容
    /// - locat: 插入的位置
    /// - Returns: 添加後的字符串
    func stringInsert(content: String,locat: Int) -> String {
        if !(locat < characters.count) { return "截取超出範圍" }
        let str1 = stringCut(end: locat)
        let str2 = stringCutToEnd(star: locat)
        return str1 + content + str2
    }
}複製代碼

8.延時使用,異步延時,主線程執行

使用:正則表達式

let sleep = delay(0.7) {
        /// 執行代碼
    }複製代碼

使用過程當中不想執行了swift

cancel(sleep)複製代碼
源碼以下:
//MARK: 延時使用 ____________________________________________________________________________________________________

typealias Task = (_ cancel : Bool) -> Void

func delay(_ time: TimeInterval, task: @escaping ()->()) ->  Task? {

    func dispatch_later(block: @escaping ()->()) {
        let t = DispatchTime.now() + time
        DispatchQueue.main.asyncAfter(deadline: t, execute: block)
    }

    var closure: (()->Void)? = task
    var result: Task?

    let delayedClosure: Task = {
        cancel in
        if let internalClosure = closure {
            if (cancel == false) {
                DispatchQueue.main.async(execute: internalClosure)
            }
        }
        closure = nil
        result = nil
    }

    result = delayedClosure

    dispatch_later {
        if let delayedClosure = result {
            delayedClosure(false)
        }
    }
    return result
}

func cancel(_ task: Task?) {
    task?(true)
}複製代碼

更新繼續,若是您以爲對你有幫助 來個星星贊助下😋

相關文章
相關標籤/搜索