一对一直播系统源码,UICollectionViewCell自适应文字宽度
2021/11/4 14:39:41
本文主要是介绍一对一直播系统源码,UICollectionViewCell自适应文字宽度,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
一对一直播系统源码,UICollectionViewCell自适应文字宽度实现的相关代码
自定义cell
#pragma mark — 自定义cell #import "SelfSizingCollectCell.h" #import "Masonry.h" #define itemHeight 60 @implementation SelfSizingCollectCell - (instancetype)initWithFrame:(CGRect)frame{ self = [super initWithFrame:frame]; if (self) { self.contentView.backgroundColor = [UIColor redColor]; // 用约束来初始化控件: self.textLabel = [[UILabel alloc] init]; self.textLabel.textAlignment =NSTextAlignmentCenter; self.textLabel.backgroundColor = [UIColor greenColor]; [self.contentView addSubview:self.textLabel]; #pragma mark — 如果使用CGRectMake来布局,是需要在preferredLayoutAttributesFittingAttributes方法中去修改textlabel的frame的 // self.textLabel = [[UILabel alloc] initWithFrame:CGRectMake(0, 0, frame.size.width, 30)]; #pragma mark — 如果使用约束来布局,则无需在preferredLayoutAttributesFittingAttributes方法中去修改cell上的子控件l的frame [self.textLabel mas_makeConstraints:^(MASConstraintMaker *make) { // make 代表约束: make.top.equalTo(self.contentView).with.offset(0); make.left.equalTo(self.contentView).with.offset(0); make.height.equalTo(@(itemHeight/2)); make.right.equalTo(self.contentView).with.offset(0); }]; } return self; } #pragma mark — 实现自适应文字宽度的关键步骤:item的layoutAttributes - (UICollectionViewLayoutAttributes *)preferredLayoutAttributesFittingAttributes:(UICollectionViewLayoutAttributes *)layoutAttributes{ UICollectionViewLayoutAttributes *attributes = [super preferredLayoutAttributesFittingAttributes:layoutAttributes]; CGRect rect = [self.textLabel.text boundingRectWithSize:CGSizeMake(CGFLOAT_MAX, itemHeight) options:NSStringDrawingTruncatesLastVisibleLine | NSStringDrawingUsesFontLeading | NSStringDrawingUsesLineFragmentOrigin attributes:@{NSFontAttributeName: [UIFont systemFontOfSize:14]} context:nil]; rect.size.width +=8; rect.size.height+=8; attributes.frame = rect; return attributes; } @end
Controller中关键
#pragma mark — 视图控制器中使用:(关键) layout.estimatedItemSize = CGSizeMake(20, 60); // layout约束这边必须要用estimatedItemSize才能实现自适应,使用itemSzie无效 以上就是一对一直播系统源码,UICollectionViewCell自适应文字宽度实现的相关代码, 更多内容欢迎关注之后的文章
这篇关于一对一直播系统源码,UICollectionViewCell自适应文字宽度的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-05-04安装 VPrix Desktop 的系统要求-icode9专业技术文章分享
- 2024-05-01巧用 TiCDC Syncpoint 构建银行实时交易和准实时计算一体化架构
- 2024-05-01银行核心背后的落地工程体系丨Oracle - TiDB 数据迁移详解
- 2024-04-26高性能表格工具VTable总体构成-icode9专业技术文章分享
- 2024-04-16软路由代理问题, tg 无法代理问题-icode9专业技术文章分享
- 2024-04-16程序猿用什么锅-icode9专业技术文章分享
- 2024-04-16自建 NAS 的方案-icode9专业技术文章分享
- 2024-04-14ansible 在远程主机上执行脚本,并传入参数-icode9专业技术文章分享
- 2024-04-14ansible 在远程主机上执行脚本,并传入参数, 加上remote_src: yes 配置-icode9专业技术文章分享
- 2024-04-14ansible 检测远程主机的8080端口,如果关闭,则echo 进程已关闭-icode9专业技术文章分享