控件文字过长的显示处理

本文介绍了在iOS开发中如何使用不同模式对UILabel或UIButton中的文本进行截断显示,包括通过设置lineBreakMode属性实现多种截断效果,并提供了包含图片时调整文字宽度的方法。

这个处理不局限一种控件,如果是单行的话,为了显示全乎,使用sizeToFit也行,如果是为了统一,就多余文字变成...就需要使用:

self.nameBtn.titleLabel.lineBreakMode = NSLineBreakByTruncatingTail;

点进去lineBreakModel可以的看到:

@property(nonatomic)        NSLineBreakMode    lineBreakMode;   // default is NSLineBreakByTruncatingTail. used for single and multiple lines of text

他有几种模式:

// NSParagraphStyle
typedef NS_ENUM(NSInteger, NSLineBreakMode) {
    NSLineBreakByWordWrapping = 0,     	// Wrap at word boundaries, default
    NSLineBreakByCharWrapping,		// Wrap at character boundaries
    NSLineBreakByClipping,		// Simply clip
    NSLineBreakByTruncatingHead,	// Truncate at head of line: "...wxyz"
    NSLineBreakByTruncatingTail,	// Truncate at tail of line: "abcd..."
    NSLineBreakByTruncatingMiddle	// Truncate middle of line:  "ab...yz"
} NS_ENUM_AVAILABLE(10_0, 6_0);

可以看到有A...B、AB...、...AB等多种。

可以自己选择需要的。

如果包含图片,可以自己判断一下文字所需宽度,之后在控制偏移

比如:

 [button setTitleEdgeInsets:UIEdgeInsetsMake(0, 10, 0, 10)];
    CGFloat width = kMainScreenWidth - 60;
    width = (width > [button.titleLabel.text boundingRectWithSize:CGSizeMake(MAXFLOAT, 20) options:NSStringDrawingUsesLineFragmentOrigin attributes:@{NSFontAttributeName:kMainBoldFontT36} context:nil].size.width)?[button.titleLabel.text boundingRectWithSize:CGSizeMake(MAXFLOAT, 20) options:NSStringDrawingUsesLineFragmentOrigin attributes:@{NSFontAttributeName:kMainBoldFontT36} context:nil].size.width:width;
    [button setImageEdgeInsets:UIEdgeInsetsMake(0,  width+ 15, 0, -width - 15)];

或者 ,你也可以用uitextview来当做显示文字的控件

-(UITextView *)infoTextView{
    
    if (!_infoTextView) {
        _infoTextView = [[UITextView alloc]init];
        _infoTextView.text = self.info;
        _infoTextView.textAlignment = NSTextAlignmentLeft;
        _infoTextView.textColor = kMainColor000000;
        _infoTextView.font = kMainFontT28;
        _infoTextView.backgroundColor = [UIColor clearColor];
        _infoTextView.userInteractionEnabled = YES;
        _infoTextView.editable = NO;
        _infoTextView.selectable = NO;
        _infoTextView.showsVerticalScrollIndicator = NO;
        _infoTextView.contentInset = UIEdgeInsetsMake(-8, -4, 0, -8);
        CGSize size = CGSizeMake(10.0f, 10.0f);
        [_infoTextView setContentSize:size];
        [self.bgView addSubview:_infoTextView];
    }
    return _infoTextView;
}

这里需要注意的是如果你关闭了用户交互,那么当文字过多的时候,就不可以滑动了,编辑,选中关了要不就可以选中了,但是貌似showsVerticalScrollIndicator关不掉。。。emmmm

转载于:https://my.oschina.net/rainwz/blog/1863614

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值