适配iOS 开发每天分享优质文章iOS三方应用

Masonry实现多个Label横排显示效果

2022-04-21  本文已影响0人  calary

一、前言

我们在开发中经常会用到Masonry来实现自动布局,有时候实现两个Label横向排列时,如果设置了右侧label距离right的间距,则会出现不连续的情况,为此我们需要用下面两个参数来处理显示情况

  • contentHuggingPriority 抗拉伸
  • contentCompressionResistancePriority 抗压缩

二、效果展示(常规情况)

    UILabel *leftLabel = [[UILabel alloc] init];
    leftLabel.backgroundColor = [UIColor redColor];
    leftLabel.text = @"左侧文字";
    leftLabel.textColor = [UIColor whiteColor];
    [self.view addSubview:leftLabel];
    
    UILabel *rightLabel = [[UILabel alloc] init];
    rightLabel.backgroundColor = [UIColor blueColor];
    rightLabel.text = @"右侧文字";
    rightLabel.textColor = [UIColor whiteColor];
    [self.view addSubview:rightLabel];
    
    [leftLabel mas_makeConstraints:^(MASConstraintMaker *make) {
        make.left.offset(10);
        make.top.offset(100);
    }];
    
    [rightLabel mas_makeConstraints:^(MASConstraintMaker *make) {
        make.left.mas_equalTo(leftLabel.mas_right).offset(10);
        make.right.offset(-10);
        make.centerY.mas_equalTo(leftLabel);
    }];
常规样式
leftLabel.text = @"左侧文字一二三四五六七八九十";
rightLabel.text = @"右侧文字一二三四五六七八九十";
长度过长

三、设置后的效果(抗压缩、抗拉伸)

1、setContentHuggingPriority 抗拉伸,这个值越低,就会在宽度多余的情况下,被拉伸,默认250
2、setContentCompressionResistancePriority 抗压缩,这个值越低,就会在宽度不够的情况下,被压缩,默认是750

leftLabel.text = @"左侧文字";
rightLabel.text = @"右侧文字";
// 设置抗拉伸属性,left的值大于right的值,这个值越低,就会在宽度多余的情况下,被拉伸
[leftLabel setContentHuggingPriority:UILayoutPriorityRequired forAxis:UILayoutConstraintAxisHorizontal];
[rightLabel setContentHuggingPriority:UILayoutPriorityDefaultLow forAxis:UILayoutConstraintAxisHorizontal];
image.png
leftLabel.text = @"左侧文字一二三四五六七八九十";
rightLabel.text = @"右侧文字一二三四五六七八九十";
// 设置抗压缩属性,left的值小于right的值,这个值越低,就会在宽度不够的情况下,被压缩
[leftLabel setContentCompressionResistancePriority:UILayoutPriorityDefaultLow forAxis:UILayoutConstraintAxisHorizontal];
[rightLabel setContentCompressionResistancePriority:UILayoutPriorityRequired forAxis:UILayoutConstraintAxisHorizontal];
image.png

四、延展

[leftLabel mas_makeConstraints:^(MASConstraintMaker *make) {
       make.left.offset(10);
      // 最小的宽度
       make.width.mas_greaterThanOrEqualTo(@(150));
       make.top.offset(100);
 }];
[rightLabel mas_makeConstraints:^(MASConstraintMaker *make) {
       make.left.mas_equalTo(leftLabel.mas_right).offset(10);
       make.right.offset(-10);
       make.centerY.mas_equalTo(leftLabel);
}];
image.png
[leftLabel mas_makeConstraints:^(MASConstraintMaker *make) {
       make.left.offset(10);
       make.top.offset(100);
}];
    
[rightLabel mas_makeConstraints:^(MASConstraintMaker *make) {
       make.left.mas_equalTo(leftLabel.mas_right).offset(10);
       make.right.offset(-10);
       make.centerY.mas_equalTo(leftLabel);
       // 最大的宽度
       make.width.mas_lessThanOrEqualTo(@(150));
 }];
image.png
上一篇 下一篇

猜你喜欢

热点阅读