setContentCompressionResistancePriority和setContentHuggingPriority使用总结

说实话我花了不少时间才真正理解setContentCompressionResistancePriority和setContentHuggingPriority的用法。

[label1 setContentCompressionResistancePriority:758 forAxis:(UILayoutConstraintAxisHorizontal)];

[label1 setContentHuggingPriority:300 forAxis:(UILayoutConstraintAxisHorizontal)];

setContentCompressionResistancePriority(抗压缩),这个值越低,就会在宽度不够的情况下,被压缩。常见的视图默认给的值是UILayoutPriorityDefaultHigh = 750。若是多个视图是默认值,会被系统认为更早被addSubview的视图该值更小!

setContentHuggingPriority(抗拉伸),这个值越低,就会在宽度多余的情况下,被拉伸。常见的视图默认给的值是UILayoutPriorityDefaultLow = 250。若是多个视图是默认值,会被系统认为更早被addSubview的值更小!

下面举个栗子验证下:

import "CompressionAndHuggingViewController.h"

#

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在UIStackView中分配比例可以使用分布属性(distribution property)。分布属性可以在Storyboard或通过编程方式进行设置。以下是一些示例: 1. 在Storyboard中分配比例: - 选择您的UIStackView。 - 在属性检查器中,找到“Distribution”选项,并将其更改为“Fill Equally”(平均分配)或“Fill Proportionally”(按比例分配)。 - 如果您选择“Fill Proportionally”,则可以通过更改每个子视图的“Proportion”属性来设置每个子视图的比例。 2. 通过编程方式分配比例: - 在代码中,使用以下代码访问您的UIStackView的分布属性: ``` stackView.distribution = .fillEqually // 平均分配 stackView.distribution = .fillProportionally // 按比例分配 ``` - 如果您选择“Fill Proportionally”,则可以使用以下代码设置每个子视图的比例: ``` subview1.setContentHuggingPriority(UILayoutPriority(249), for: .horizontal) subview1.setContentCompressionResistancePriority(UILayoutPriority(749), for: .horizontal) subview2.setContentHuggingPriority(UILayoutPriority(249), for: .horizontal) subview2.setContentCompressionResistancePriority(UILayoutPriority(749), for: .horizontal) // 其他子视图的比例设置 ``` - setContentHuggingPriority(_:for :)和setContentCompressionResistancePriority(_:for :)方法分别设置子视图的拉伸优先级和压缩优先级。根据这些优先级和UIStackView的大小,系统将计算每个子视图的大小和位置。 ### 回答2: UIStackView是iOS开发中非常常用的一种容器视图,它可以帮助我们快速搭建界面,并且自动进行内部子视图的布局管理。 在UIStackView中分配子视图的比例显示是非常简单的,我们可以通过设置子视图的布局属性来实现。 首先,我们需要将UIStackView的distribution属性设置为.fillEqually,这样会将子视图平均分配到UIStackView中。 接下来,我们可以通过设置子视图的占比来实现比例显示。UIStackView提供了一个子视图的属性arrangedSubviews,我们可以通过该属性获取到UIStackView内部的子视图数组。 我们可以通过索引访问数组中的子视图,并设置子视图的布局属性,比如widthAnchor或heightAnchor来实现分配的比例显示。 例如,如果我们有三个子视图,我们可以设置第一个子视图的widthAnchor为其他两个子视图的一半,第二个子视图的widthAnchor为其他两个子视图的四分之一,最后一个子视图的widthAnchor为其他两个子视图的四分之一。 代码示例如下: ``` let stackView = UIStackView() stackView.distribution = .fillEqually let subview1 = UIView() stackView.addArrangedSubview(subview1) subview1.widthAnchor.constraint(equalTo: stackView.widthAnchor, multiplier: 0.5).isActive = true let subview2 = UIView() stackView.addArrangedSubview(subview2) subview2.widthAnchor.constraint(equalTo: stackView.widthAnchor, multiplier: 0.25).isActive = true let subview3 = UIView() stackView.addArrangedSubview(subview3) subview3.widthAnchor.constraint(equalTo: stackView.widthAnchor, multiplier: 0.25).isActive = true ``` 通过以上设置,我们可以实现UIStackView中子视图按照一定的比例显示的效果。 ### 回答3: UIStackView是iOS开发中的一个布局容器,可以用来水平或垂直地排列一组视图。通过设置UIStackView的distribution属性,可以控制其中视图的分布比例。 UIStackView的distribution属性有四种可选值: 1. Fill:视图被拉伸到填满整个UIStackView,不保持原始尺寸比例。 2. Fill Equally:视图被平均拉伸到填满整个UIStackView,并保持原始尺寸比例。 3. Fill Proportionally:视图根据其原始尺寸比例进行拉伸,以填满整个UIStackView。 4. Equal Spacing:视图之间的间距保持相等,视图尺寸根据自身内容决定。 如果想要实现分比例显示,可以通过设置UIStackView中视图的布局约束来控制。可以使用视图的宽度或高度约束,设置其优先级为低,然后在UIStackView的distribution属性中选择Fill Proportionally或Equal Spacing。这样,视图将会根据其原始尺寸比例进行拉伸或保持等间距分布。 例如,如果有两个视图A和B,希望A的宽度是B的宽度的2倍。可以设置A的宽度约束为等于B的宽度的2倍,并将约束的优先级设置为低。然后,在UIStackView的distribution属性中选择Fill Proportionally,这样A和B的宽度将会按照2:1的比例来显示。 可以根据具体的需求,使用布局约束和UIStackView的distribution属性来实现不同比例的视图显示。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值