SnapKit使用学习

使用注意:先添加控件到父视图,再设置约束

一、基本使用实践

      let redview = UIView()
        redview.backgroundColor = UIColor.red
        view.addSubview(redview)
        redview.snp.makeConstraints { (make) in
            make.width.height.equalTo(100)//宽高设置为100
            make.top.equalTo(view.snp.top).offset(100)//顶部约束相对于父控件的顶部偏移了100
            make.centerX.equalTo(self.view.snp.centerX)//使控件的x轴中心点和父控件中心点对齐
        }
      let redview = UIView()
        redview.backgroundColor = UIColor.red
        view.addSubview(redview)
          redview.snp.makeConstraints { (make) in
            make.size.equalTo(CGSize(width: 100, height: 100))//宽高设置为100
            make.top.equalToSuperview().offset(100) //顶部约束相对于父控件的顶部偏移了100
            make.centerX.equalToSuperview()//使控件的x轴中心点和父控件中心点对
        }
      let redview = UIView()
        redview.backgroundColor = UIColor.red
        view.addSubview(redview)
        redview.snp.makeConstraints { (make) in
               make.size.equalTo(100) //宽高设置为100
               make.top.equalToSuperview().offset(100)
               make.centerX.equalToSuperview()
        }

 let redview = UIView()
         redview.backgroundColor = UIColor.red
        view.addSubview(redview)
        redview.snp.makeConstraints { (make) in
            make.leading.equalToSuperview().offset(30)
            make.trailing.equalToSuperview().offset(-30)
            make.top.equalToSuperview().offset(100)
            make.height.equalTo(40)
        }
let redview = UIView()
        redview.backgroundColor = UIColor.red
       view.addSubview(redview)
       redview.snp.makeConstraints { (make) in
           make.width.equalToSuperview().dividedBy(2)//宽是父控件宽度的1/2
           make.centerX.equalToSuperview()
           make.top.equalToSuperview().offset(100)
           make.height.equalTo(60)
       }

let redview = UIView()
        redview.backgroundColor = UIColor.red
       view.addSubview(redview)
        redview.snp.makeConstraints { (make) in
           make.width.equalTo(100)
           make.centerX.equalToSuperview()
           make.top.equalToSuperview().offset(100)
           make.height.equalTo(redview.snp.width).multipliedBy(2)//高等于宽的2倍
       }
let redview = UIView()
        redview.backgroundColor = UIColor.red
       view.addSubview(redview)
 redview.snp.makeConstraints { (make) in
           make.width.equalTo(100);
           make.centerX.equalToSuperview()
           make.top.equalToSuperview().offset(100);
      make.bottom.equalTo(redview.snp.top).multipliedBy(3)
           
       }
       let redview = UIView()
       redview.backgroundColor = UIColor.red
       view.addSubview(redview)
       redview.snp.makeConstraints { (make) in
       make.leading.top.equalToSuperview().offset(100)
       make.right.bottom.equalTo(view).offset(-100)
       }
        let redview = UIView()
        redview.backgroundColor = UIColor.red
        view.addSubview(redview)
        redview.snp.makeConstraints { (make) in
        make.leading.equalTo(view).offset(100)
        make.trailing.equalTo(view).offset(-100)
        make.top.equalTo(view.snp.top).offset(100)
        make.bottom.equalToSuperview().offset(-100)
        }
       let redview = UIView()
        redview.backgroundColor = UIColor.red
        view.addSubview(redview)
 let redview = UIView()
        redview.backgroundColor = UIColor.red
        view.addSubview(redview)
        redview.snp.makeConstraints { (make) in
          make.edges.equalTo(UIEdgeInsetsMake(100, 100, 100, 100))
        }
      

二 、UILable自适应

  • 1、缺少一个竖直或水平方向的约束让宽或高自适应
    let lable = UILabel()
        lable.backgroundColor=UIColor.yellow
        lable.numberOfLines = 0
        view.addSubview(lable)
        lable.text =
        "或许在某个生命宇宙,有幸与时光擦身邂逅,盛满兴衰的枯荣或许在某个生命宇宙,有幸与时光擦身邂逅,盛满兴衰的枯荣或许在某个生命宇宙,有幸与时光擦身邂逅,盛满兴衰的枯荣"
        lable.snp.makeConstraints { (make) in
        make.top.leading.equalToSuperview().offset(100)
        make.width.equalTo(100)
        }

  • 2、在一个范围内约束自适应
      let lable = UILabel()
        lable.backgroundColor=UIColor.yellow
        lable.numberOfLines = 0
        view.addSubview(lable)
        lable.text =
        "或许"
        lable.snp.makeConstraints { (make) in
        make.top.leading.equalToSuperview().offset(100)
        make.width.greaterThanOrEqualTo(100)//宽度约束最小为100
        make.width.lessThanOrEqualTo(200)//宽度超过100,在200以内宽度自适应大小,宽度约束最大是200
        }

三、父控件的高度随子控件的高度改变而改变

1、子控件约束设置

import UIKit
import SnapKit
class LogView: UIView {
    override init(frame: CGRect) {
        super.init(frame: frame)
        let imageview = UIImageView()
        imageview.backgroundColor = UIColor.yellow
        imageview.image = UIImage(named: "visitordiscover_image_message")
        self.addSubview(imageview)
        imageview.snp.makeConstraints { (make) in
            make.top.equalToSuperview().offset(30)
            make.width.equalTo(100)
            make.centerX.equalToSuperview()
            make.height.equalTo(100)//子控件高度一定
            make.bottom.equalToSuperview().offset(-30)//子控件内容粘着底部约束
        }
       
    }
    required init?(coder aDecoder: NSCoder) {
        fatalError("init(coder:) has not been implemented")
    }
}

2、父控件约束设置

  override func viewDidLoad() {
        super.viewDidLoad()
        let logview = LogView()
        logview.backgroundColor = UIColor.green
        view.addSubview(logview)
        logview.snp.makeConstraints { (make) in
          make.centerY.equalTo(self.view)
          make.left.right.equalTo(self.view)
         //高度约束不设置,这样高度就会被子控件撑开
        }
    }

你可能感兴趣的:(SnapKit使用学习)