[快速学会Swift第三方库] Cartography篇

[快速学会Swift第三方库] Cartography篇

Cartography 是用来声明 Swift 中的 Auto Layout,无需输入任何 stringly 就可设置自己 Auto Layout 的约束声明。

目录

编码之前

导入 Cartography

推荐使用CocoaPods进行导入,CocoaPods是一个负责管理iOS项目中第三方开源库的工具,安装CocoaPods之后使用命令行就能轻松地对所有第三方开源库进行安装和更新,而不需要每次上GitHub去下载。
CocoaPods的安装过程传送门:iOS 9 导入类库全面详尽过程(Ruby安装->CocoaPods安装->导入类库)
手动下载:GitHub-Cartography主页

装好CocoaPods后,修改Podfile文件内容为如下:

source 'https://github.com/CocoaPods/Specs.git'
platform :ios, '9.0'
use_frameworks!

target 'Web' do
pod 'Cartography', '~> 0.6.0'
end
xcodeproj 'Desktop/Web/Web.xcodeproj'

target后面为工程名,最后一行为工程路径(这里的Web是我的工程名)

再执行命令:

$ pod install

其他操作

另外还需要在Target->工程名->Build Settings->Search Paths->User Header Search Paths处添加Cartography所在的目录:

这里写图片描述

最后在你需要用到Cartography的类中加上:

import Cartography

基本约束

示例代码

    func baseConstrain() {
        let view1 = UIView()
        let view2 = UIView()
        view1.backgroundColor = UIColor.blueColor()
        view2.backgroundColor = UIColor.redColor()
        self.view.addSubview(view1)
        self.view.addSubview(view2)

        constrain(view1, view2) { (view1, view2) in
            //view宽度等于父视图宽度-50的一半
            view1.width == (view1.superview!.width - 50) * 0.5
            //view2的宽度等于view1宽度-50
            view2.width   == view1.width - 50
            //view的高度等于40
            view1.height == 40
            //view2的高度等于view1的高度
            view2.height == view1.height
            //view1水平居中
            view1.centerX == view1.superview!.centerX
            //view2和view1中心水平对齐
            view2.centerX == view1.centerX
            //view1的顶部离父视图的顶部距离大于20
            view1.top >= view1.superview!.top + 20
            //view2的顶部离view1的底部距离等于20
            view2.top == view1.bottom + 20
        }
    }

运行结果

这里写图片描述

替换约束

示例代码

    func replaceConstrain()  {
        let view = UIView()
        view.backgroundColor = UIColor.blueColor()
        self.view.addSubview(view)

        constrain(view) { (view) in
            view.width == 100
            view.height == 100
        }

        let group = ConstraintGroup()

        //设定view位置于左上角
        constrain(view, replace: group) { (view) in
            view.top == view.superview!.top
            view.left == view.superview!.left
        }

        //设定view位置于右下角
        constrain(view, replace: group) { (view) in
            view.bottom == view.superview!.bottom
            view.right == view.superview!.right
        }

        //执行动画
        UIView.animateWithDuration(0.5, animations: view.layoutIfNeeded)
    }

运行结果

可以看到view从左上角移动到右下角,最终如下所示:
这里写图片描述

复合约束与对齐

示例代码

    func aligning()  {
        let view1 = UIView()
        let view2 = UIView()
        let view3 = UIView()
        view1.backgroundColor = UIColor.blueColor()
        view2.backgroundColor = UIColor.redColor()
        view3.backgroundColor = UIColor.greenColor()
        self.view.addSubview(view1)
        self.view.addSubview(view2)
        self.view.addSubview(view3)

        constrain(view1, view2, view3) { (view1, view2, view3) in
            //复合约束,view1大小为父视图的1/4,位置居中
            view1.size == view1.superview!.size / 4
            view1.center == view1.superview!.center

            view2.size == view1.size / 2
            view3.size == view1.size / 3

            //3个view的顶部对齐
            align(top: view1, view2, view3)
            //3个view水平均匀分布,相邻view之间距离为10
            distribute(by: 10, horizontally: view1, view2, view3)
        }
    }

运行结果

这里写图片描述

边距

示例代码

   func edge()  {
        let view = UIView()
        view.backgroundColor = UIColor.blueColor()
        self.view.addSubview(view)

        constrain(view) { (view) in
            //view与父视图的上下左右边距均为20
            view.edges == inset(view.superview!.edges, 20, 20, 20, 20)
        }
    }

运行结果

这里写图片描述

深入学习

这里列出了最主要的几种约束,如果你希望能够更加深入地学习Cartography,可以前往GitHub-Cartography主页

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Cartography 是一个用于管理和可视化分布式系统的工具,可以帮助用户更好地理解他们的基础架构和应用程序之间的关系。Cartography 代码主要包含以下几个部分: 1. GraphBuilder:这个文件定义了一个名为 GraphBuilder 的类,它是 Cartography 的核心部分。GraphBuilder 类的主要作用是读取分布式系统的配置信息,并构建系统的拓扑图。它从各种源(包括 AWS、GCP、Kubernetes 等)读取配置信息,然后使用这些信息构建节点和边,最终形成一个完整的拓扑图。GraphBuilder 还支持自定义插件,可以扩展其功能。 2. Graph:这个文件定义了一个名为 Graph 的类,它表示 Cartography 构建的拓扑图。Graph 类包含了节点和边的信息,以及一些有关拓扑图的元数据。它还提供了一些方法,可以用于查询拓扑图中的节点和边。 3. Visualizer:这个文件定义了一个名为 Visualizer 的类,用于将 Cartography 构建的拓扑图可视化。Visualizer 类使用 Graph 类的实例作为输入,然后生成一个 SVG 文件,其中包含了拓扑图中所有节点和边的信息。Visualizer 类还支持自定义插件,可以扩展其功能。 4. Utils:这个文件包含了一些实用工具函数,例如解析 JSON 文件、生成哈希值等。 总体来说,Cartography 的代码结构比较清晰,主要分为三个部分:构建拓扑图的 GraphBuilder、表示拓扑图的 Graph 和可视化拓扑图的 Visualizer。这些组件都可以通过自定义插件进行扩展,可以方便地适应不同的分布式系统。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值