SnapKit的扩展------添加数组控制约束,和九宫格布局,等宽,等间距等布局方式

SnapKit的扩展------添加数组控制约束,和九宫格布局,等宽,等间距等布局方式

SnapKit是Swift中的一个很好用的手动控制约束的三方库
这里我就不介绍了
https://github.com/SnapKit/SnapKit
很多从OC转Swift的开发者,如果之前有使用Marsonry的话.其肯定会第一时间替换使用SnapKit

是的SnapKit就是一个类似Marsonry的库,
但是其稍微有点不足,
其没有Marsonry中对Array的扩展,也没有对等宽,等间距等方便的布局方式
所以使用SnapKit,我们有时候需要些很多约束条件来满足某些特殊的需求

这里我做了简单的扩展

https://github.com/spicyShrimp/SnapKitExtend

这里写图片描述
//数组布局
let arr = [view1, view2, view3, view4]
        
arr.snp.makeConstraints{
    $0.width.height.equalTo(100)
    $0.center.equalTo(CGPoint(x: CGFloat(arc4random_uniform(300)) + 50,
                              y: CGFloat(arc4random_uniform(300)) + 50))
}
这里写图片描述
let arr = [view1, view2, view3, view4]
         
arr.snp.makeConstraints{
    $0.width.height.equalTo(100)
}

view1.snp.makeConstraints{ $0.top.equalTo(0) }
view2.snp.makeConstraints{ $0.top.equalTo(100) }
view3.snp.makeConstraints{ $0.top.equalTo(200) }
view4.snp.makeConstraints{ $0.top.equalTo(300) } 
这里写图片描述
let arr = [view1, view2, view3, view4]

//        axisType:方向
//        fixedSpacing:中间间距
//        leadSpacing:左边距(上边距)
//        tailSpacing:右边距(下边距)
arr.snp.distributeViewsAlong(axisType: .horizontal, fixedSpacing: 10, leadSpacing: 10, tailSpacing: 10)
//        上面的可以约束x+w,还需要另外约束y+h
//        约束y和height()如果方向是纵向,那么则另外需要设置x+w
arr.snp.makeConstraints{
    $0.top.equalTo(100)
    $0.height.equalTo(CGFloat(arc4random_uniform(100) + 50))
}

这里写图片描述
let arr = [view1, view2, view3, view4]
        
//        axisType:方向
//        fixedItemLength:item对应方向的宽或者高
//        leadSpacing:左边距(上边距)
//        tailSpacing:右边距(下边距)
arr.snp.distributeViewsAlong(axisType: .vertical, fixedItemLength: 100, leadSpacing: 30, tailSpacing: 30)
//        上面的可以约束y+h,还需要另外约束x+w
//        约束y和height()如果方向是纵向,那么则另外需要设置y+h
arr.snp.makeConstraints{
    $0.width.left.equalTo(100)
}
这里写图片描述
var arr: Array<ConstraintView> = [];
for _ in 0..<9 {
    let subview = UIView()
    subview.backgroundColor = UIColor.random
    view.addSubview(subview)
    arr.append(subview)
}

//        固定大小,可变中间间距,上下左右间距默认为0,可以设置
arr.snp.distributeSudokuViews(fixedItemWidth: 100, fixedItemHeight: 100, warpCount: 3)
这里写图片描述
var arr: Array<ConstraintView> = [];
for _ in 0..<9 {
    let subview = UIView()
    subview.backgroundColor = UIColor.random
    view.addSubview(subview)
    arr.append(subview)
}

//        固定间距,可变大小,上下左右间距默认为0,可以设置
arr.snp.distributeSudokuViews(fixedLineSpacing: 10, fixedInteritemSpacing: 10, warpCount: 3)

这份扩展是前段时间写的,一直忘记分享出来,今天时间比较空闲,想起来,就拿出来分享给大家了

具体的demo
前往下载即可

https://github.com/spicyShrimp/SnapKitExtend

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,254评论 4 61
  • 此时此刻,开通简书。可以随手写作,随性分享,真好。开通之前,解读了朋友的May印记,合作塔罗占卜。如果,我的存在,...
    梦想小巫阅读 354评论 0 0
  • 奥尔夫的音乐教育从儿童音乐教育开始,并且其实施也主要是儿童音乐教育。但是奥尔夫的音乐教育,最终面对的是包括专业音乐...
    刘倩汝阅读 314评论 0 0