xib適配(大小著淆、字體、約束拴疤、富文本) - Swift版

一句代碼適配xib永部,只需要傳入superview。
例如UIViewController的xib適配只需要:
view.layoutXib()
OC版:http://www.reibang.com/p/a8eb3bbdc00f

//MARK: - UIView 擴展
public extension UIView {
    
       /** xib適配 */
    func layoutXib(_ size:AdapterSize = .phone ) {
        for constant in self.constraints {
            if constant.constant > 0.5 {
                constant.constant = AdaWidth(constant.constant,size)
            }
        }
        layoutChildView(view: self)
    }
    
    fileprivate func layoutView(_ size:AdapterSize = .phone){
        var returnRect = CGRect()
        returnRect.size.width = ADAPTATION_WIDTH(self.XlbWidth, size)
        returnRect.size.height = ADAPTATION_WIDTH(self.XlbHeight, size)
        returnRect.origin.x = ADAPTATION_WIDTH(self.XlbX, size)
        returnRect.origin.y = ADAPTATION_WIDTH(self.XlbY, size)
        self.frame = returnRect
        
        if self.isKind(of: UITextField.self) {
            let viewField = self as! UITextField
            var newFont:UIFont?
            if let font = viewField.font {
                newFont = getFontWith(font)
                //viewField.font = newFont
            }
            if let attributedStr:NSMutableAttributedString = viewField.attributedText?.mutableCopy() as? NSMutableAttributedString {
                attributedStr.enumerateAttributes(in: NSRange(location: 0,length: viewField.text?.utf16.count ?? 0), options: .longestEffectiveRangeNotRequired, using: { (dic, range, stop) in
                    attributedStr.removeAttribute(.font, range: range)
                    let font:UIFont = dic[NSAttributedString.Key.font] as! UIFont
                    attributedStr.addAttributes([NSAttributedString.Key.font:(font == newFont) ? newFont! : getFontWith(font)], range: range)
                })
                viewField.attributedText = attributedStr
            }
            
            /** 設(shè)置PlaceHolder */
            if viewField.attributedPlaceholder?.length ?? 0 > 0 {
                let placeAttributedStr:NSMutableAttributedString = viewField.attributedPlaceholder?.mutableCopy() as! NSMutableAttributedString
                placeAttributedStr.enumerateAttributes(in: NSRange(location: 0,length: viewField.placeholder?.utf16.count ?? 0), options: .longestEffectiveRangeNotRequired, using: { (dic, range, stop) in
                    placeAttributedStr.removeAttribute(.font, range: range)
                    let font:UIFont = dic[NSAttributedString.Key.font] as! UIFont
                    placeAttributedStr.addAttributes([NSAttributedString.Key.font:(font == newFont) ? newFont! : getFontWith(font)], range: range)
                })
                viewField.attributedPlaceholder = placeAttributedStr
            }
            
        } else if self.isKind(of: UIButton.self) {
            let viewButton = self as! UIButton
            if let font = viewButton.titleLabel?.font {
                viewButton.titleLabel!.font = getFontWith(font)
            }
        } else if self.isKind(of: UILabel.self) {
            let viewLabel = self as! UILabel
            var newFont:UIFont?
            if let font = viewLabel.font {
                newFont = getFontWith(font)
                //viewLabel.font = newFont
            }
            if let attributedStr:NSMutableAttributedString = viewLabel.attributedText?.mutableCopy() as? NSMutableAttributedString {
                attributedStr.enumerateAttributes(in: NSRange(location: 0,length: viewLabel.text?.utf16.count ?? 0), options: .longestEffectiveRangeNotRequired, using: { (dic, range, stop) in
                    attributedStr.removeAttribute(.font, range: range)
                    let font:UIFont = dic[NSAttributedString.Key.font] as! UIFont
                    attributedStr.addAttributes([NSAttributedString.Key.font:(font == newFont) ? newFont! : getFontWith(font)], range: range)
                })
                viewLabel.attributedText = attributedStr
            }
        } else if self.isKind(of: UITextView.self) {
            let viewTextView  = self as! UITextView
            var newFont:UIFont?
            if let font = viewTextView.font {
                newFont = getFontWith(font)
                //viewTextView.font = newFont
            }
            if let attributedStr:NSMutableAttributedString = viewTextView.attributedText.mutableCopy() as? NSMutableAttributedString {
                attributedStr.enumerateAttributes(in: NSRange(location: 0,length: viewTextView.text?.utf16.count ?? 0), options: .longestEffectiveRangeNotRequired, using: { (dic, range, stop) in
                    attributedStr.removeAttribute(.font, range: range)
                    let font:UIFont = dic[NSAttributedString.Key.font] as! UIFont
                    attributedStr.addAttributes([NSAttributedString.Key.font:(font == newFont) ? newFont! : getFontWith(font)], range: range)
                })
                viewTextView.attributedText = attributedStr
            }
        }
    }
   
    /** View轉(zhuǎn)Image */
    func imageWithView() ->(UIImage) {
        let imageSize = self.bounds.size
        UIGraphicsBeginImageContextWithOptions(imageSize, false, UIScreen.main.scale)
        self.layer.render(in: UIGraphicsGetCurrentContext()!)
        let image = UIGraphicsGetImageFromCurrentImageContext()!
        UIGraphicsEndImageContext()
        return image
    }
    
    var XlbX: CGFloat {
        get { return self.frame.origin.x}
        set(value) {
            var origin = self.frame.origin
            origin.x = value
            self.frame.origin = origin
        }
    }
    var XlbY: CGFloat {
        get { return self.frame.origin.y}
        set(value) {
            var origin = self.frame.origin
            origin.y = value
            self.frame.origin = origin
        }
    }
    var XlbCenterX: CGFloat {
        get { return self.center.x}
        set(value) {
            var center = self.center
            center.x = value
            self.center = center
        }
    }
    var XlbCenterY: CGFloat {
        get { return self.center.y}
        set(value) {
            var center = self.center
            center.y = value
            self.center = center
        }
    }
    var XlbWidth: CGFloat {
        get { return self.frame.size.width}
        set(value) {
            var size = self.frame.size
            size.width = value
            self.frame.size = size
        }
    }
    var XlbRight: CGFloat {
        get { return self.frame.size.width + self.frame.origin.x}
    }
    var XlbHeight: CGFloat {
        get { return self.frame.size.height}
        set(value) {
            var size = self.frame.size
            size.height = value
            self.frame.size = size
        }
    }
    var XlbBottom: CGFloat {
        get { return self.frame.size.height + self.frame.origin.y}
    }
    var XlbOrigin: CGPoint {
        get { return self.frame.origin}
        set(value) {
            self.frame.origin = value
        }
    }
    var XlbSize: CGSize {
        get { return self.frame.size}
        set(value) {
            self.frame.size = value
        }
    }
}

//遞歸獲取子視圖
private func layoutChildView(view:UIView) {
    let subViews = view.subviews
    if subViews.count == 0 {
        return
    }
    for subView in subViews {
        subView.layoutXib(.phone)
        subView.layoutView()
    }
}

func getFontWith(_ font:UIFont) ->UIFont {
    let fontSize:CGFloat! = font.pointSize
    let fontName:String! = font.fontName
    
    var fontType:FontType = .Regular
    
    if fontName.hasSuffix("Medium") {
        fontType = .Medium
    } else
    if fontName.hasSuffix("Regular") {
        fontType = .Regular
    } else
    if fontName.hasSuffix("Semibold") {
        fontType = .Semibold
    } else
    if fontName.hasSuffix("Bold") {
        fontType = .Bold
    } else
    if fontName.hasSuffix("Heavy") {
        fontType = .Heavy
    } else
    if fontName.hasSuffix("Light") {
        fontType = .Light
    } else
    if fontName.hasSuffix("Ultralight") {
        fontType = .Ultralight
    } else
    if fontName.hasSuffix("Thin") {
        fontType = .Thin
    }
    
    return FONT(fontSize,fontType)
}


/** 字體 */
public enum FontType:String{
    case Medium = "PingFangSC-Medium"
    case Thin = "PingFangSC-Thin"
    case Regular = "PingFangSC-Regular"
    case Semibold = "PingFangSC-Semibold"
    case Bold = "Helvetica-Bold"
    case Light = "PingFangSC-Light"
    case Heavy = ".SFUI-Heavy"
    case Ultralight = "PingFangSC-Ultralight"
    case Number = "DINEngschrift"
    case Saira = "Saira-Black"
}

public enum AdapterSize:CGFloat{
    ///普通設(shè)計尺寸375
    case phone = 375.0
    ///iPhoneX系列設(shè)計尺寸414
    case phoneMax = 414.0
}
/** 獲取屏幕寬度 */
public var MAINSCREEN_WIDTH: CGFloat {
    get {
        return UIScreen.main.bounds.size.width
    }
}
public func ADAPTATION_WIDTH( _ value:CGFloat, _ size:AdapterSize = .phone) -> CGFloat {
    return (MAINSCREEN_WIDTH > 428 ? 428 : MAINSCREEN_WIDTH) * value / size.rawValue
}
public func FONT(_ Font:CGFloat,_ type:FontType = .Regular, size:AdapterSize = .phone) -> UIFont {
    let font:UIFont! = UIFont.init(name: type.rawValue, size:(MAINSCREEN_WIDTH > 428 ? 428 : MAINSCREEN_WIDTH) * Font / size.rawValue)
    return font
}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末呐矾,一起剝皮案震驚了整個濱河市苔埋,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌蜒犯,老刑警劉巖组橄,帶你破解...
    沈念sama閱讀 216,591評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件荞膘,死亡現(xiàn)場離奇詭異,居然都是意外死亡晨炕,警方通過查閱死者的電腦和手機衫画,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,448評論 3 392
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來瓮栗,“玉大人削罩,你說我怎么就攤上這事》鸭椋” “怎么了弥激?”我有些...
    開封第一講書人閱讀 162,823評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長愿阐。 經(jīng)常有香客問我微服,道長,這世上最難降的妖魔是什么缨历? 我笑而不...
    開封第一講書人閱讀 58,204評論 1 292
  • 正文 為了忘掉前任以蕴,我火速辦了婚禮,結(jié)果婚禮上辛孵,老公的妹妹穿的比我還像新娘丛肮。我一直安慰自己,他們只是感情好魄缚,可當(dāng)我...
    茶點故事閱讀 67,228評論 6 388
  • 文/花漫 我一把揭開白布宝与。 她就那樣靜靜地躺著,像睡著了一般冶匹。 火紅的嫁衣襯著肌膚如雪习劫。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,190評論 1 299
  • 那天嚼隘,我揣著相機與錄音诽里,去河邊找鬼。 笑死飞蛹,一個胖子當(dāng)著我的面吹牛须肆,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播桩皿,決...
    沈念sama閱讀 40,078評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼豌汇,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了泄隔?” 一聲冷哼從身側(cè)響起拒贱,我...
    開封第一講書人閱讀 38,923評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后逻澳,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體闸天,經(jīng)...
    沈念sama閱讀 45,334評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,550評論 2 333
  • 正文 我和宋清朗相戀三年斜做,在試婚紗的時候發(fā)現(xiàn)自己被綠了苞氮。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,727評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡瓤逼,死狀恐怖笼吟,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情霸旗,我是刑警寧澤贷帮,帶...
    沈念sama閱讀 35,428評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站诱告,受9級特大地震影響撵枢,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜精居,卻給世界環(huán)境...
    茶點故事閱讀 41,022評論 3 326
  • 文/蒙蒙 一锄禽、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧靴姿,春花似錦沃但、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,672評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽恨旱。三九已至辈毯,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間搜贤,已是汗流浹背谆沃。 一陣腳步聲響...
    開封第一講書人閱讀 32,826評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留仪芒,地道東北人唁影。 一個月前我還...
    沈念sama閱讀 47,734評論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像掂名,于是被迫代替她去往敵國和親据沈。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,619評論 2 354

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