温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

iOS中如何解决lebel特殊字符自动换行的问题

发布时间:2021-07-28 14:30:00 来源:亿速云 阅读:402 作者:小新 栏目:移动开发

小编给大家分享一下iOS中如何解决lebel特殊字符自动换行的问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

前言

如果在label自动换行的时候,碰到特殊的字符串时候,我不想特殊字符串换行分开,该如何实现???

iOS中如何解决lebel特殊字符自动换行的问题
问题图片

说一下刚看到这个问题的时候,自己的思路:

      1.想将事件字符串转化成一个图片,在使用NSTextAttachment结合NSAttributedString,来将图片显示在label上面,但是百度下将将文字转化成图片,看了一下,这么长的代码,列表上面太多的回复,考虑到性能的要求,果断放弃了。

      2.计算回复内容的最后一个字符的frame,在去计算时间的长度,总和来判断是否要换行,感觉还行,但是看到那么多的计算,小编也放弃了。

实在想不起来怎么实现了,不行就按照步骤2的实现方法试试吧,刚好这个时候,妹子来电话了,和妹子闲扯了半小时,挂断电话,没办法,想吧,写吧,终于让我想到一个简单的方法

最终的结果

我们可以先计算,回复内容的宽高A,再计算一次加上时间的宽高B,我们来比较A和B的高度,如果不一样,那就是在时间这里刚好换行,我们就可以在内容和时间之间添加\n进行换行

结论

想不起来,就和妹子聊聊天,总有想起来的时候,不然多浪费青春年华!!!

Demo如下

 let label = UILabel();
 var text = "七秒记忆鱼儿注,转发请备注七秒注,么么哒!";
 label.numberOfLines = 0;
 label.font = UIFont.systemFont(ofSize: 15);
 let size = text.wj_computedTextHeight(font: 15, size: CGSize.init(width: view.bounds.width, height: CGFloat(MAXFLOAT)));
 var text1 = text;
 text.append("七秒最帅");
 let size1 = text.wj_computedTextHeight(font: 15, size: CGSize.init(width: view.bounds.width, height: CGFloat(MAXFLOAT)));
 if size.height != size1.height {
 text1.append("\n");
 text1.append("七秒最帅");
 text = text1;
 }
 label.text = text;
 label.frame = CGRect.init(x: 10, y: 64, width: size1.width, height: size1.height);
 view.addSubview(label);

抽取的方法

/// 计算文字的size
///
/// - parameter font: 大小
/// - parameter size: 文本的打下
///
/// - returns: 返回size
func wj_computedTextHeight(font:CGFloat,size:CGSize)->CGSize{
 print(self,size);
 let str = self as NSString;
 let maxSize = str.boundingRect(with: size, options:NSStringDrawingOptions.usesLineFragmentOrigin, attributes: [NSFontAttributeName:UIFont.systemFont(ofSize: font)], context: nil).size

 return maxSize;
}

最终的效果

iOS中如何解决lebel特殊字符自动换行的问题

以上是“iOS中如何解决lebel特殊字符自动换行的问题”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI