xib适配(大小、字体、约束、富文本) - Swift版

一句代码适配xib,只需要传入superview。
例如UIViewController的xib适配只需要:
view.layoutXib()
OC版:https://www.jianshu.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
            }
            
            /** 设置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转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{
    ///普通设计尺寸375
    case phone = 375.0
    ///iPhoneX系列设计尺寸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
}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,080评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,422评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,630评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,554评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,662评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,856评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,014评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,752评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,212评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,541评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,687评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,347评论 4 331
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,973评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,777评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,006评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,406评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,576评论 2 349

推荐阅读更多精彩内容