我取名 setContentHuggingPriority为 “抗拉伸”(这个名字我自己认为比较准确);setContentCompressionResistancePriority 取名为“抗压缩”,接下来有个小例子,里面解释的也是挺详细的
UILabel * label = [[UILabel alloc]init]; [self.view addSubview:label]; label.backgroundColor = [UIColor yellowColor]; UILabel * label2 = [[UILabel alloc]init]; [self.view addSubview:label2]; label2.backgroundColor = [UIColor blueColor]; /* * intrinsicContentSize: 这个是label 的真实的 大小size * 抗拉伸 和 抗压缩 都是相对于intrinsicContentSize 值来说的 **/ #if 0 /* * 抗拉伸 * 主要用在 * eg:label、label2 限制后 还有空余空间,这个时候就需要谁来拉伸了,才能满足我们的限制 * setContentHuggingPriority(值越高,越不容易拉伸,所以我取名为‘抗拉伸’) **/ label.text = @"label"; label2.text = @"label2"; /* * 保证label 不被拉伸,那么只能拉伸label2 **/ [label setContentHuggingPriority:UILayoutPriorityRequired forAxis:UILayoutConstraintAxisHorizontal]; [label2 setContentHuggingPriority:UILayoutPriorityDefaultLow forAxis:UILayoutConstraintAxisHorizontal]; #else /* * 抗压缩 * 主要用在 * eg:label、label2 限制后 ,没有空余空间,这个时候就 只能压缩某个label,才能满足我们的限制 * setContentCompressionResistancePriority(值越高,越不容易压缩,所以我取名为‘抗压缩’) **/ label.text = @"hello,我是第一个label,请多多!"; label2.text = @"hello,我是第二个label,谢谢"; /* * 保证label2 不被压缩,那么只能压缩label **/ [label setContentCompressionResistancePriority:UILayoutPriorityDefaultLow forAxis:UILayoutConstraintAxisHorizontal]; [label2 setContentCompressionResistancePriority:UILayoutPriorityDefaultHigh forAxis:UILayoutConstraintAxisHorizontal]; #endif [label mas_makeConstraints:^(MASConstraintMaker *make) { make.left.equalTo(@10); make.top.equalTo(@10); make.right.equalTo(label2.mas_left).offset(-20); }]; [label2 mas_makeConstraints:^(MASConstraintMaker *make) { make.left.equalTo(label.mas_right).offset(20); make.top.equalTo(label); make.right.equalTo(@(-10)); }];
狂戳这里去下载demo 查看一下
作者:LeeDev
链接:http://www.jianshu.com/p/5cf559435eb9
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。