对于单行/多行 字符串文本size的 获取,如何取得文本高度和宽度

比如有这么几个数据:

@property (nonatomic,assign) long Id;
@property (nonatomic,copy) NSString *createdAt;
@property (nonatomic,copy) NSString *mbtype;
@property (nonatomic,copy) NSString *profileImageUrl;
@property (nonatomic,copy) NSString *source;
@property (nonatomic,copy) NSString *text;
@property (nonatomic,copy) NSString *userName;

要获取文本字符串的size 可以这么做:

单行文本 createdAt , source userName 调用 (CGSize)sizeWithAttributes:(NSDictionary *)attrs; 来获取文本的高度和宽度

例:

CGFloat userNameX = CGRectGetMaxX(_avatar.frame) + kStatusTableViewCellControlSpacing;
    CGFloat userNameY = avatarY;
    CGSize userNameSize = [contacts.userName <span style="color:#FF0000;">sizeWithAttributes</span>:@{NSFontAttributeName:[UIFont systemFontOfSize:12]}];
    _userName.text = contacts.userName;
    _userName.frame = CGRectMake(userNameX, userNameY, userNameSize.width, userNameSize.height);

多行文本text 调用 (CGRect)boundingRectWithSize:(CGSize)size options:(NSStringDrawingOptions)options attributes:(NSDictionary *)attributes context:(NSStringDrawingContext *)context ;方法来得到文本宽度和高度;同时注意在此之前需要设置文本控件的 numberOfLines属性为0


例:

CGFloat textX=avatarX;
    CGFloat textY=CGRectGetMaxY(_avatar.frame)+kStatusTableViewCellControlSpacing;
    CGFloat textWidth=self.frame.size.width-kStatusTableViewCellControlSpacing*2;
    CGSize textSize=[status.text <span style="color:#FF0000;">boundingRectWithSize</span>:CGSizeMake(textWidth, MAXFLOAT) 
<span style="color:#FF0000;">options</span>:NSStringDrawingUsesLineFragmentOrigin 
<span style="color:#FF0000;">attributes</span>:@{NSFontAttributeName: [UIFont systemFontOfSize:kStatusTableViewCellTextFontSize]} <span style="color:#FF0000;">context</span>:nil].size;
    CGRect textRect=CGRectMake(textX, textY, textSize.width, textSize.height);
    _text.text = contacts.text;
    _text.frame = textRect;



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值