常用方法

進行旋轉(zhuǎn)
-(CABasicAnimation *)getTransformAnimation{
    CABasicAnimation *animation   = [CABasicAnimation animationWithKeyPath:@"transform.rotation"]; //指定對transform.rotation屬性做動畫
    animation.duration            = 2.0f; //設(shè)定動畫持續(xù)時間
    animation.byValue             = @(M_PI*2); //設(shè)定旋轉(zhuǎn)角度盾碗,單位是弧度
    animation.fillMode            = kCAFillModeForwards;//設(shè)定動畫結(jié)束后再扭,不恢復初始狀態(tài)之設(shè)置一
    animation.repeatCount         = 1000;//設(shè)定動畫執(zhí)行次數(shù)
    animation.removedOnCompletion = NO;//設(shè)定動畫結(jié)束后,不恢復初始狀態(tài)之設(shè)置二
    return animation;
}
將 data 轉(zhuǎn) String
        var s = String(format: "%@", deviceToken as CVarArg)
        s = s.replacingOccurrences(of: " ", with: "")
        s = s.replacingOccurrences(of: "<", with: "")
        s = s.replacingOccurrences(of: ">", with: "")
圓形圖片的切割
func circleImage(_ orign_image:UIImage?) -> UIImage? {   
    if let image = orign_image {
        UIGraphicsBeginImageContext(image.size)
        // 獲得上下文
        if let ctx = UIGraphicsGetCurrentContext() {
            // 矩形框
            let rect = CGRect(x: 0, y: 0, width: image.size.width, height: image.size.height)
            // 添加一個圓
            ctx.addEllipse(in: rect)
            // 裁剪(裁剪成剛才添加的圖形形狀)
            ctx.clip()
            // 往圓上面畫一張圖片
            image.draw(in: rect)
            // 獲得上下文中的圖片
            if let newImg = UIGraphicsGetImageFromCurrentImageContext() {
                // 關(guān)閉圖形上下文
                UIGraphicsEndImageContext()
                return newImg
            }
            // 關(guān)閉圖形上下文
            UIGraphicsEndImageContext()
        }
    }
    return nil
    
}
設(shè)置 UIBarButtonItem
func barButtonItems(withImage image:String,hightLightImage:String,target:Any,action:Selector) -> UIBarButtonItem {
    let btn = UIButton(type: .custom)
    btn.setImage(UIImage(named:image), for: .normal)
    btn.setImage(UIImage(named:hightLightImage), for: .highlighted)
    btn.sizeToFit()
    btn.addTarget(target, action: action, for: .touchUpInside)
    let view = UIView(frame: btn.frame)
    view.addSubview(btn)
    return UIBarButtonItem(customView: view)
}

func barButtonItems(withTitle title:String,target:Any,action:Selector) -> UIBarButtonItem {
    let btn = UIButton(type: .custom)
    btn.setTitle(title, for: .normal)
    btn.setTitleColor(.white, for: .normal)
    btn.sizeToFit()
    btn.addTarget(target, action: action, for: .touchUpInside)
    let view = UIView(frame: btn.frame)
    view.addSubview(btn)
    return UIBarButtonItem(customView: view)
}

找當前控制器

   func findPresentingVC() -> (UIViewController){
    var window = UIApplication.shared.keyWindow
    if window?.windowLevel != UIWindowLevelNormal {
        let windows = UIApplication.shared.windows
        for win in windows {
            if win.windowLevel == UIWindowLevelNormal {
                window = win
                break
            }
        }
    }
    var resulet = window?.rootViewController
    while ((resulet?.presentedViewController) != nil) {
        resulet = resulet?.presentedViewController
    }
    if (resulet?.isKind(of: UITabBarController.self)) ?? false {
        resulet = (resulet as? UITabBarController)?.selectedViewController
    }
    if (resulet?.isKind(of: UINavigationController.self)) ?? false {
        resulet = (resulet as? UINavigationController)?.topViewController
    }
    guard let vc = resulet else {
        return UIViewController()
    }
    return vc
}

常用的正則

/// 手機號
func validateMobile( _ str : String ) -> Bool {
    let Regex = "^((13[0-9])|(15[012356789])|(17[678])|(18[0-9])|(14[57]))\\d{8}$"
    let Test = NSPredicate(format: "SELF MATCHES %@", Regex)
    return Test.evaluate(with: str)
}
/// 車牌
func validateCarNo( _ str : String ) -> Bool {
    let Regex = "[\u{4e00}-\u{9fa5}]{1}[a-zA-Z]{1}[a-zA-Z_0-9]{4}[a-zA-Z_0-9_\u{4e00}-\u{9fa5}]$"
    let Test = NSPredicate(format: "SELF MATCHES %@", Regex)
    return Test.evaluate(with: str)
}
/// 用戶名
func validateUserName( _ str : String ) -> Bool {
    let Regex = "^[A-Za-z0-9]{6,20}+$"
    let Test = NSPredicate(format: "SELF MATCHES %@", Regex)
    return Test.evaluate(with: str)
}
/// 密碼
func validatePassword( _ str : String ) -> Bool {
    let Regex = "^[a-zA-Z0-9]{6,16}+$"
    let Test = NSPredicate(format: "SELF MATCHES %@", Regex)
    return Test.evaluate(with: str)
}
/// 昵稱
func validateNickname( _ str : String ) -> Bool {
    let Regex = "^[\u{4e00}-\u{9fa5}]{4,8}$"
    let Test = NSPredicate(format: "SELF MATCHES %@", Regex)
    return Test.evaluate(with: str)
}
/// 身份證號
func validateIdentityCard( _ str : String ) -> Bool {
    var flag : Bool = true
    if (str as NSString).length <= 0 {
        flag = false
        return flag
    }
    let Regex = "^(\\d{14}|\\d{17})(\\d|[xX])$"
    let Test = NSPredicate(format: "SELF MATCHES %@", Regex)
    return Test.evaluate(with: str)
}
/// 昵稱
func validataURL( _ str : String ) -> Bool {
    let Regex = "^http://([\\w-]+\\.)+[\\w-]+(/[\\w-./?%&=]*)?$"
    let Test = NSPredicate(format: "SELF MATCHES %@", Regex)
    return Test.evaluate(with: str)
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末饺蚊,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子屡拨,更是在濱河造成了極大的恐慌谷饿,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,029評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件专挪,死亡現(xiàn)場離奇詭異,居然都是意外死亡片排,警方通過查閱死者的電腦和手機寨腔,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,395評論 3 385
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來率寡,“玉大人迫卢,你說我怎么就攤上這事∮铝樱” “怎么了?”我有些...
    開封第一講書人閱讀 157,570評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長比默。 經(jīng)常有香客問我幻捏,道長,這世上最難降的妖魔是什么命咐? 我笑而不...
    開封第一講書人閱讀 56,535評論 1 284
  • 正文 為了忘掉前任篡九,我火速辦了婚禮,結(jié)果婚禮上醋奠,老公的妹妹穿的比我還像新娘榛臼。我一直安慰自己,他們只是感情好窜司,可當我...
    茶點故事閱讀 65,650評論 6 386
  • 文/花漫 我一把揭開白布沛善。 她就那樣靜靜地躺著,像睡著了一般塞祈。 火紅的嫁衣襯著肌膚如雪金刁。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,850評論 1 290
  • 那天议薪,我揣著相機與錄音尤蛮,去河邊找鬼。 笑死斯议,一個胖子當著我的面吹牛产捞,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播哼御,決...
    沈念sama閱讀 39,006評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼坯临,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了艇搀?” 一聲冷哼從身側(cè)響起尿扯,我...
    開封第一講書人閱讀 37,747評論 0 268
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎焰雕,沒想到半個月后衷笋,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,207評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡矩屁,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,536評論 2 327
  • 正文 我和宋清朗相戀三年辟宗,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片吝秕。...
    茶點故事閱讀 38,683評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡泊脐,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出烁峭,到底是詐尸還是另有隱情容客,我是刑警寧澤秕铛,帶...
    沈念sama閱讀 34,342評論 4 330
  • 正文 年R本政府宣布,位于F島的核電站缩挑,受9級特大地震影響但两,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜供置,卻給世界環(huán)境...
    茶點故事閱讀 39,964評論 3 315
  • 文/蒙蒙 一谨湘、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧芥丧,春花似錦紧阔、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,772評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至赤拒,卻和暖如春秫筏,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背挎挖。 一陣腳步聲響...
    開封第一講書人閱讀 32,004評論 1 266
  • 我被黑心中介騙來泰國打工这敬, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人蕉朵。 一個月前我還...
    沈念sama閱讀 46,401評論 2 360
  • 正文 我出身青樓崔涂,卻偏偏與公主長得像,于是被迫代替她去往敵國和親始衅。 傳聞我的和親對象是個殘疾皇子冷蚂,可洞房花燭夜當晚...
    茶點故事閱讀 43,566評論 2 349

推薦閱讀更多精彩內(nèi)容