SwiftyFitsize
Example
克隆或下载仓库到本地后,请先运行 pod install
, 再打开 SwiftyFitsize.xcworkspace
Requirements
- iOS 9.0+
- Xcode 10.2+
- Swift 5+
Installation
- Cocoapods
use_frameworks!
pod 'SwiftyFitsize'
- Swift Package Manager
1. File > Add Packages
2. Search https://github.com/LinXunFeng/SwiftyFitsize.git
3. Select "Up to Next Major" with "1.4.1"
Exhibition
Usage
一、运算符
无论是
~
还是≈
对iPhone
的适配效果是一样的。而对iPad
而言,iPad
的宽度太大,使用≈
还是会按宽度比例进行运算,就会显示特别臃肿,这时使用~
在显示上就会比较合适。
~
在≈
的基础上针对iPad
的适配大小后再去乘上iPadFitMultiple
。- 一般情况下直接使用
~
即可。- 其它运算符亦是如此,具体请看下方的说明表
运算符 | 说明 |
---|---|
~ |
对比宽度,当设备为 iPad 时,适配后的 value 会再乘上 iPadFitMultiple |
≈ |
对比宽度,强制适配,不论是 iPhone 还是 iPad 都不会乘上 iPadFitMultiple |
∣ |
对比高度,对应 ~ ,整屏高度 |
∥ |
对比高度,对应 ≈ ,整屏高度 |
∣= |
对比高度,对应 ∣ ,安全区域内的高度 |
∥= |
对比高度,对应 ∥ ,安全区域内的高度 |
∣- |
对比高度,对应 ∣ ,除去刘海区域的安全区域内的高度 |
∥- |
对比高度,对应 ∥ ,除去刘海区域的安全区域内的高度 |
各高度适配的对比
- 红色:
∣
和∥
,以整个屏幕的高度进行适配- 蓝色:
∣=
和∥=
以中心安全区域的高度进行适配- 绿色:
∣-
和∥-
以包括底部的安全区域进行适配
举个例子
~
: 当设备为 iPad
时,适配后的值会与 iPadFitMultiple
相乘
100~
UIFont.systemFont(ofSize: 14)~
CGPoint(x: 10, y: 10)~
CGRect(x: 10, y: 10, width: 100, height: 100)~
UIEdgeInsetsMake(10, 10, 10, 10)~
≈
: (option + x) 适配后的值不会与 iPadFitMultiple
相乘
100≈
UIFont.systemFont(ofSize: 14)≈
CGPoint(x: 10, y: 10)≈
CGRect(x: 10, y: 10, width: 100, height: 100)≈
UIEdgeInsetsMake(10, 10, 10, 10)≈
修改 参照宽度
、参照高度
、是否为iPhoneX系列的参照高度
与 iPadFitMultiple
可以调用如下方法
/// 设置参照的相关参数
///
/// - Parameters:
/// - width: 参照的宽度
/// - height: 参照的高度
/// - isIPhoneXSeriesHeight: 是否为iPhoneX系列的参照高度
/// - iPadFitMultiple: iPad 在适配后所得值的倍数 (0 , 1]
SwiftyFitsize.reference(
width: 414,
height: 896,
isIPhoneXSeriesHeight: true,
iPadFitMultiple: 0.5
)
二、支持 xib 和 storyboard
enum SwiftyFitType: Int {
/// Original Value
case none = 0
/// ~
case flexibleWidth = 1
/// ≈
case forceWidth = 2
/// ∣
case flexibleHeight = 3
/// ∥
case forceHeight = 4
/// ∣=
case flexibleSafeAreaCenterHeight = 5
/// ∥=
case forceSafeAreaCenterHeight = 6
/// ∣-
case flexibleSafeAreaWithoutTopHeight = 7
/// ∥-
case forceSafeAreaWithoutTopHeight = 8
}
- Font Fitsize
支持的UI控件有: UILabel
UIButton
UITextView
UITextField
FontFitType
的值请参考上方的 enum SwiftyFitType
- Constraint Fitsize
约束适配同上
iPad
关于 ~
与 ≈
在使用上的对比
三、Objective-C
由于
OC
不支持运算符重载,所以只能用宏来适配。
Xib
和Storyboard
则跟上方提及的使用方式相同。
Swift运算符
与 OC宏
对应表
Swift运算符 | OC宏 |
---|---|
~ |
SF_xx |
≈ |
SFZ_xx |
∣ |
SF_FH_xx |
∥ |
SFZ_FH_xx |
∣= |
SF_SCH_xx |
∥= |
SFZ_SCH_xx |
∣- |
SF_SBH_xx |
∥- |
SFZ_SBH_xx |
注: xx
支持如下类型 Font
、Int
、Float
、Point
、Size
、Rect
、EdgeInsets
- 导入
@import SwiftyFitsize;
注:如果你使用的是
SPM
添加的依赖,且需要使用到宏(如:SF_Float
),则需要导入
SwiftyFitsizeOCSupport
,而SwiftyFitsize
可以不导入。
@import SwiftyFitsizeOCSupport;
- 修改
参照宽度
、参照高度
、是否为iPhoneX系列的参照高度
与iPadFitMultiple
[SwiftyFitsize referenceWithWidth:414
height:896
isIPhoneXSeriesHeight:YES
iPadFitMultiple:0.6];
~
UIFont *font = [UIFont systemFontOfSize:14];
UIFont *font1 = font.sf;
UIFont *font2 = SF_Font(font);
CGFloat num = SF_Float(14);
CGPoint point = SF_Point(CGPointMake(10, 10));
CGSize size = SF_Size(CGSizeMake(100, 100));
CGRect rect = SF_Rect(CGRectMake(10, 10, 100, 100));
UIEdgeInsets edge = SF_EdgeInsets(UIEdgeInsetsMake(0, 0, 100, 100));
≈
UIFont *font1 = font.sfz;
UIFont *font2 = SFZ_Font(font);
CGFloat num = SFZ_Float(14);
CGPoint point = SFZ_Point(CGPointMake(10, 10));
CGSize size = SFZ_Size(CGSizeMake(100, 100));
CGRect rect = SFZ_Rect(CGRectMake(10, 10, 100, 100));
UIEdgeInsets edge = SFZ_EdgeInsets(UIEdgeInsetsMake(0, 0, 100, 100));
其它运算符亦是如此使用
四、移除指定尺寸后适配
场景:
tableView
的左右间距在屏幕大小不同的情况下都为10
,在排除左右为10
的间距后,再对Cell
进行等比适配使用思路:宽度一共减去
20
,以剩下的大小来做适配
Swift
建议使用 PropertyWrapper
方案,供下面的调用方式一和二使用
struct Metric {
static let tableViewLeftRightMargin: CGFloat = 10 // 定义 tableView 的左右间距
...
static let tableViewHeight: CGFloat = Fit.$width(30) // 去掉左右边距后进行适配的值
static let rowLeftViewWidth: CGFloat = Fit.$width(177.5)
static let rowCenterViewWidth: CGFloat = Fit.$width(100.5)
static let rowRightViewWidth: CGFloat = Fit.$width(77)
...
}
struct Fit {
// @WrappedSwiftyFitsize(fitType: .flexibleWidth, reduceValue: Metric.tableViewLeftRightMargin)
// fitType 默认值是 .flexibleWidth,所以可以不传
@WrappedSwiftyFitsize(reduceValue: Metric.tableViewLeftRightMargin * 2)
static var width: CGFloat = 375
}
375
是初始化值,没有特殊意义,只为调用 Fit.width
时可以取到值,如果用不到 Fit.width
的值可以不进行初始化
调用方式:
// 移除指定尺寸后的适配,调用方式:
// 以下都是以适配 tableView 为例,移除 tableView 左右两侧固定的边距,以剩余的宽度来做适配
// 方式一:先赋值再取值
// 将 20 进行适配
Fit.width = 20
print("适配后的值 -- \(Fit.width)")
// 方式二:使用 $ 将 width 当方法用,传入待适配的值
// 将 30 进行适配
let aVal = Fit.$width(30)
print("适配后的值 aVal -- \(aVal)")
// 方式三:调用 SwiftyFitsize.fit 方法
let bVal = SwiftyFitsize.fit(
size: 40,
fitType: .flexibleWidth,
reduceValue: Metric.tableViewLeftRightMargin * 2
)
print("适配后的值 bVal -- \(bVal)")
Objective-C
这是还是以适配 tableView
为例,移除 tableView 左右两侧固定的边距,以剩余的宽度来做适配
CGFloat fitWidth = [SwiftyFitsize fitWithSize:40
fitType:SwiftyFitTypeFlexibleWidth
reduceValue:20];
可以将其做为宏,以方便使用
#define kFitWidth(value) \
[SwiftyFitsize fitWithSize:value fitType:SwiftyFitTypeFlexibleWidth reduceValue:20]
使用宏来做适配
CGFloat fitWidth = kFitWidth(40);
NSLog(@"fitWidth -- %f", fitWidth);
效果如包含红绿蓝的条视图所示:
五、计算结果类型
定义
/// 计算结果类型
@objc public enum SwiftyFitCalcResultType: Int {
/// 跟随全局配置
case globalConfig
/// 原始数据
case raw
/// 四舍五入
case round
/// 保留一位小数(根据第二位小数进行四舍五入)
case oneDecimalPlace
}
影响范围
.raw
: 影响忽略不计.round
: 影响范围(-0.5, 0.5]
.oneDecimalPlace
: 影响范围(-0.05, 0.05]
全局配置
- 不配置则默认为
.raw
.globalConfig
取的就是这里配置的类型- 如果在该处还是设置为
.globalConfig
,则内部会将其重置为.raw
SwiftyFitsize.reference(width: 375, calcResultType: .oneDecimalPlace) // 全局配置计算结果为保留一位小数
使用
以下在不指定
calcResultType
参数的情况下,默认都是跟随全局配置
单独指定 calcResultType
SwiftyFitsize.fit(
size: 35, // 36
fitType: .flexibleWidth,
reduceValue: 10 * 2,
calcResultType: .raw // .round .oneDecimalPlace
)
PropertyWrapper
方式
// calcResultType: .raw .round .oneDecimalPlace
@WrappedSwiftyFitsize(reduceValue: Metric.tableViewLeftRightMargin * 2, calcResultType: .raw)
static var width: CGFloat = 375
示例数据
-
第一列为适配前的数值
-
其它列为适配后根据不同的
SwiftyFitCalcResultType
计算得到的值
原值 | raw | round | oneDecimalPlace |
---|---|---|---|
35 | 36.478873239436616 | 36.0 | 36.5 |
36 | 37.52112676056338 | 38.0 | 37.5 |
Misc
下面列出一些设备对应的分辨率,方便查找
设备 | 逻辑分辨率(point) | 设备分辨率(pixel) |
---|---|---|
SE | 320x568 | 640x1136 |
6(S)/7/8 / SE(第二代) | 375x667 | 750x1334 |
6(S)+/7+/8+ | 414x736 | 1080x1920 |
X(S) / 11Pro | 375x812 | 1125x2436 |
XR / 11 | 414x896 | 828x1792 |
XS Max / 11Pro Max | 414x896 | 1242x2688 |
12 mini / 13 mini | 360x780 | 1080x2340 |
12(Pro) / 13(Pro) | 390x844 | 1170x2532 |
12 Pro Max / 13 Pro Max | 428x926 | 1284x2778 |
License
SwiftyFitsize is available under the MIT license. See the LICENSE file for more info.
Author
- LinXunFeng
- email: linxunfeng@yeah.net
- Blogs: 全栈行动 | LinXunFeng‘s Blog | 掘金