swift纯代码实现自动布局

简介: swift纯代码实现自动布局

早期的IOS设备都是固定屏幕的尺寸,所以大家写iOS应用几乎都是用frame布局,直接写死宽高和坐标。

但是iPhone6开始,iOS设备出现了多种尺寸,于是苹果推出了一种新的布局方式:`autolayout`

autolaout又名自动布局,或者是是相对布局。使用autolayout可以轻易写出目前主流的所有页面布局。

关闭autoresizing布局方式

在 iOS中,默认使用aotoresizing的布局方式来写页面,autoresizing相对来说比较简单。只做了相对于父控件的大小的伸缩。使用起来不是特别顺手。

控件的translatesAutoresizingMaskIntoConstraints为false,可以启用自动布局

NSLayoutConstraint简单了解

顾名思义,这是创建一个布局约束

NSLayoutConstraint(item: 当前的控件, attribute: 约束属性, relatedBy: 前后之间的关系, toItem: 相对的控件, attribute: 相对控件的某个属性, multiplier: 比例, constant: 常量)

比如

NSLayoutConstraint(item:myview , attribute: .left, relatedBy: .equal, toItem: self.view, attribute: .left, multiplier: 1, constant: 0)

意思就是myview左边相对于self.view的左边,距离为0

创建一个与ViewController一样大的View

let myview = UIView();
        self.view.addSubview(myview)
        myview.translatesAutoresizingMaskIntoConstraints = false
        myview.backgroundColor = UIColor.systemBlue
        let left = NSLayoutConstraint(item:myview , attribute: .left, relatedBy: .equal, toItem: self.view, attribute: .left, multiplier: 1, constant: 0)
        let right = NSLayoutConstraint(item: myview
                                       , attribute: .right, relatedBy: .equal, toItem: self.view
                                       , attribute: .right, multiplier: 1, constant: 0)
        let top = NSLayoutConstraint(item: myview
                                     , attribute: .top, relatedBy: .equal, toItem: self.view, attribute: .top, multiplier: 1, constant: 0)
        let bottom = NSLayoutConstraint(item: myview
                                        , attribute: .bottom, relatedBy: .equal, toItem: self.view, attribute: .bottom, multiplier: 1, constant: 0)
        myview.superview?.addConstraints([left,right,top,bottom])

约束某个某个属性为固定值

比如我们需要设置当前view的宽度为100.高度为200

let myview = UIView();
        self.view.addSubview(myview)
        myview.translatesAutoresizingMaskIntoConstraints = false
        myview.backgroundColor = UIColor.systemBlue
        let left = NSLayoutConstraint(item:myview , attribute: .left, relatedBy: .equal, toItem: self.view, attribute: .left, multiplier: 1, constant: 0)
        let width = NSLayoutConstraint(item: myview
                                       , attribute: .width, relatedBy: .equal, toItem: nil
                                       , attribute: .notAnAttribute, multiplier: 1, constant: 100)
        let top = NSLayoutConstraint(item: myview
                                     , attribute: .top, relatedBy: .equal, toItem: self.view, attribute: .top, multiplier: 1, constant: 0)
        let height = NSLayoutConstraint(item: myview
                                        , attribute: .height, relatedBy: .equal, toItem: nil, attribute: .notAnAttribute, multiplier: 1, constant: 200)
        myview.superview?.addConstraints([left,width,top,height])

View居中

let myview = UIView();
        self.view.addSubview(myview)
        myview.translatesAutoresizingMaskIntoConstraints = false
        myview.backgroundColor = UIColor.systemBlue
        let centerX = NSLayoutConstraint(item:myview , attribute: .centerX, relatedBy: .equal, toItem: self.view, attribute: .centerX, multiplier: 1, constant: 0)
        let width = NSLayoutConstraint(item: myview
                                       , attribute: .width, relatedBy: .equal, toItem: nil
                                       , attribute: .notAnAttribute, multiplier: 1, constant: 100)
        let centerY = NSLayoutConstraint(item: myview
                                     , attribute: .centerY, relatedBy: .equal, toItem: self.view, attribute: .centerY, multiplier: 1, constant: 0)
        let height = NSLayoutConstraint(item: myview
                                        , attribute: .height, relatedBy: .equal, toItem: nil, attribute: .notAnAttribute, multiplier: 1, constant: 200)
        myview.superview?.addConstraints([centerX,width,centerY,height])

View动画

目录
相关文章
|
6月前
|
程序员 Swift iOS开发
使用XCode11.2.1创建swift5纯代码主页
使用XCode11.2.1创建swift5纯代码主页
47 2
|
Swift iOS开发
swift语言IOS8开发战记5.使用纯代码的方式实现tableViewCell
storyboad的拖拽关联给我们开发带来了很大的便利,但是在目前的很多公司进行IOS开发时是禁止员工使用storyboard的,纯代码的实现方式仍然是主流,对于Swift这样一门新兴语言,加强语言的使用,使用纯代码来实现,不仅迎合了目前公司的用人要求,也更有利于我们深入理解Swift语法。
1354 0
|
6月前
|
安全 编译器 Swift
IOS开发基础知识: 对比 Swift 和 Objective-C 的优缺点。
IOS开发基础知识: 对比 Swift 和 Objective-C 的优缺点。
381 2
|
4月前
|
Unix 调度 Swift
苹果iOS新手开发之Swift 中获取时间戳有哪些方式?
在Swift中获取时间戳有四种常见方式:1) 使用`Date`对象获取秒级或毫秒级时间戳;2) 通过`CFAbsoluteTimeGetCurrent`获取Core Foundation的秒数,需转换为Unix时间戳;3) 使用`DispatchTime.now()`获取纳秒级精度的调度时间点;4) `ProcessInfo`提供设备启动后的秒数,不表示绝对时间。不同方法适用于不同的精度和场景需求。
131 3
|
10天前
|
Swift iOS开发 UED
如何使用Swift和UIKit在iOS应用中实现自定义按钮动画
本文通过一个具体案例,介绍如何使用Swift和UIKit在iOS应用中实现自定义按钮动画。当用户点击按钮时,按钮将从圆形变为椭圆形,颜色从蓝色渐变到绿色;释放按钮时,动画以相反方式恢复。通过UIView的动画方法和弹簧动画效果,实现平滑自然的过渡。
24 1
|
19天前
|
Swift iOS开发 UED
如何使用Swift和UIKit在iOS应用中实现自定义按钮动画
【10月更文挑战第18天】本文通过一个具体案例,介绍如何使用Swift和UIKit在iOS应用中实现自定义按钮动画。当用户按下按钮时,按钮将从圆形变为椭圆形并从蓝色渐变为绿色;释放按钮时,动画恢复原状。通过UIView的动画方法和弹簧动画效果,实现平滑自然的动画过渡。
42 5
|
3月前
|
存储 移动开发 Swift
使用Swift进行iOS应用开发:探索现代移动开发的魅力
【8月更文挑战第12天】使用Swift进行iOS应用开发,不仅能够享受到Swift语言带来的简洁、快速、安全的编程体验,还能够充分利用iOS平台提供的丰富资源和强大功能。然而,iOS应用开发并非易事,需要开发者具备扎实的编程基础、丰富的实践经验和不断学习的精神。希望本文能够为您的iOS应用开发之旅提供一些有益的参考和帮助。
|
4月前
|
Swift iOS开发 Kotlin
苹果iOS新手开发之Swift中实现类似Kotlin的作用域函数
Swift可通过扩展实现类似Kotlin作用域函数效果。如自定义`let`, `run`, `with`, `apply`, `also`,增强代码可读性和简洁性。虽无直接内置支持,但利用Swift特性可达成相似功能。
70 7
|
4月前
|
调度 Swift Android开发
苹果iOS新手开发之Swift中的并发任务和消息机制
Swift的消息机制类似Android的Handler,实现任务调度有三种方式: 1. **Grand Central Dispatch (GCD)**:使用`DispatchQueue`在主线程或后台线程执行任务。 2. **OperationQueue**:提供高级接口管理`Operation`对象。 3. **RunLoop**:处理事件如输入源、计时器,类似Android的`Looper`和`Handler`。 **示例**: - GCD:在不同线程执行代码块。 - OperationQueue:创建操作并执行。 - RunLoop:用Timer添加到RunLoop中。
97 2
|
4月前
|
安全 编译器 Swift
探索iOS开发:Swift语言的现代魔法
【7月更文挑战第11天】本文深入探讨了Swift编程语言,它如何革新iOS开发领域,以及它为开发者带来的独特优势。我们将从Swift的基础语法出发,通过实际案例分析其性能优化技巧,最后讨论Swift在跨平台开发中的潜力。文章旨在为读者提供一个全面而深入的视角,了解Swift不仅仅是一门语言,更是一种推动创新的力量。