首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

iOS开发小技巧:根据文本,字体,计算UILabel高度及宽度

需求: 根据字符串,字体,计算UILabel宽度 根据字符串,字体,宽度,计算UILabel高度 2....实现示例: UILabel+Size分类,实现代码 UILabel+Size.h // // UILabel+Size.h // Created by ChenMan on 2018/1/25...options: 文本绘制时的附加选项。可能取值请参考“NSStringDrawingOptions”。 attributes: 文本绘制时用到的AttributedString的属性。...包括一些信息,例如如何调整字间距以及缩放。最终,该对象包含的信息将用于文本绘制。该参数一般为 nil 。 返回值: 一个矩形,大小等于文本绘制完将占据的宽和高。...练习题:封装一个根据字体,字符串,宽度等参数得到高度的方法?

5.4K10

MyLayout&TangramKit 的重大升级!

AutoLayout的尺寸自适应 AutoLayout中有两种类型的尺寸自适应:一类是以UILabel和UITextView为代表视图的尺寸自适应,这类视图中的宽度和高度有时候需要根据自身内容来确定自己的宽度和高度...那就是当添加或者删除子视图时以及调整了某个子视图的位置和尺寸时就需要重新调整父视图的自适应约束设置。...; } 实现中针对某个cell返回一个特定高度值UITableViewAutomaticDimension。...; } 实现中针对某个cell返回一个特定高度值UITableViewAutomaticDimension。...因此如果想使用布局视图的尺寸自适应功能,那么在将布局视图的尺寸设置为wrap后,就可以像使用UILabel那样不用去设置布局视图的宽度约束和高度约束了。比如有两个兄弟视图A,B。

2.1K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Cell 动态行高文字显示不全问题探索

    ,为了使文本可以多行显示,需要保证如下设置: 设置 label 的 numberoflines 为 0 对 label 进行上左下右的完整约束 在项目实现过程中,遇到了文本内容被截断最后一行一小部分,无法完全显示的问题...为了复现项目中遇到的此问题并找到原因,做了如下尝试: 一、新建工程 新建工程测试,cell上下约束完备,底部高度约束 contentLblBtmCon 为>=9,优先级默认1000。...小结 重写 cell 的 setFrame 方法改变 cell 高度来实现分割线效果时,可能导致多行 label 显示不全,此时,可以通过降低底部约束优先级为 Low + 增加底部约束的值(cell 间距...),来实现想要的文本多行显示效果。...其他解决思路 当然,为了实现行分割线效果,我们也可以在自定义 cell 的底部手动添加一个 UIView 子视图,高度设置为 cell 间隔高度,颜色改为与 UITableview 背景色一致(与 cell

    2.3K00

    Cell 动态行高文字显示不全问题探索

    ,为了使文本可以多行显示,需要保证如下设置: 设置 label 的 numberoflines 为 0 对 label 进行上左下右的完整约束 在项目实现过程中,遇到了文本内容被截断最后一行一小部分,无法完全显示的问题...为了复现项目中遇到的此问题并找到原因,做了如下尝试: 一、新建工程 新建工程测试,cell上下约束完备,底部高度约束 contentLblBtmCon 为>=9,优先级默认1000。...通过 log 可知,内容 label 的高度约束被舍弃了,因此会出现内容显示不全的问题。模拟器运行效果: ? 尝试解决 修改contentLblBtmCon优先级为High(750) ?...),来实现想要的文本多行显示效果。...其他解决思路 当然,为了实现行分割线效果,我们也可以在自定义 cell 的底部手动添加一个 UIView 子视图,高度设置为 cell 间隔高度,颜色改为与 UITableview 背景色一致(与 cell

    1.9K20

    iOS文本尺寸自适应异步计算实现

    目前市面上的非UI线程文本算高方法或多或少都有一些问题。本文通过逆向和分析UILabel的sizeThatFits方法实现来得到一个最佳的文本算高的精简方法。.../// github地址:https://github.com/youngsoft /// 计算简单文本或者属性字符串的自适应尺寸 /// @param fitsSize 指定限制的尺寸,参考UILabel.../// @param text 要计算的简单文本NSString或者属性字符串NSAttributedString对象 /// @param numberOfLines 指定最大显示的行数,如果为0则表示不限制最大行数.../// @param font 指定计算时文本的字体,可以为nil表示使用UILabel控件的默认17号字体 /// @param textAlignment 指定文本对齐方式默认是NSTextAlignmentNatural...fitsSize的值, 这里的宽度调整为只要宽度小于等于0或者显示一行都不限制宽度,而高度则总是改为不限制高度。

    1.5K40

    iOS 优化界面流畅的技巧

    如果你对文本显示没有特殊要求,可以参考下 UILabel 内部的实现方式: 用 [NSAttributedString boundingRectWithSize:options:context:]...常见的文本控件 (UILabel、UITextView 等),其排版和绘制都是在主线程进行的,当显示大量文本时,CPU 的压力会非常大。...尽管这实现起来非常麻烦,但其带来的优势也非常大,CoreText 对象创建好后,能直接获取文本的宽高等信息,避免了多次计算(调整 UILabel 大小时算一遍、UILabel 绘制时内部再算一遍);CoreText...CellLayout 包含所有文本的 CoreText 排版结果、Cell 内部每个控件的高度、Cell 的整体高度。...为了达到最高性能,你可能需要牺牲一些开发速度,不要用 Autolayout 等技术,少用 UILabel 等文本控件。

    1.5K10

    记一次 contentInsetAdjustmentBehavior 引发的bug

    1 背景 项目中使用到了UILable来展示相关的文本内容,但内容的大小不确定,有可能会超过屏幕的大小,因此需要在外层嵌套一个UIScrollView来保证内容可以被完全展现给用户,在UILabel确定相关的高度后...= UILabel() ..........//设置scrollView的可滚动范围为 titleLabel的高度加上上面的距离30 //scrollView.contentSize = CGSize(width: 0, height...”,它的类型为UIScrollView.ContentInsetAdjustment,主要有几个值: automatic :自动调整 scrollableAxes:只调整在可滚动方向的 never :...不调整 always :在调整内容时,自己调整 并且在iOS 11以上的系统,该属性的默认值为always,也就是说在你调整它的contentSize时,系统会自动帮你调整子View的偏移量,这其实也解释了在排查方向二时出现的现象

    82420

    UI篇-CATextLayer和 富文本的交融

    而NSMutableAttributedString有可以最自己内容作出颜色以及大小的调整,这样结合起来使用的话,就远比UILabel 灵活的多,效果也酷炫的多,也许CATextLayer就是为了NSMutableAttributedString...有属性的控件有UILabel、UITextField和UITextView。...greenColor]; //自动换行 label.numberOfLines = 0; //设置label的富文本 label.attributedText = attrStr; //label高度自适应...; //label高度自适应[label sizeToFit]; [self.view addSubview:label]; 文本属性Attributes 1.直接上干货,多个属性可以一同使用 //...,取值为 NSString 对象,目前只有图版印刷效果可用: //NSAttachmentAttributeName NSTextAttachment 设置文本附件,常用插入图片 //NSLinkAttributeName

    2.6K10

    iOS 设置tableViewCell的高度

    前言 iOS tableView的cell在显示之前必须获取cell的高度,如果cell的高度都一样,统一设置就行了,但是cell的高度不统一的话就要一一设置了,在ios8之前,需要自己手动去计算,iOS...; } iOS8以上(包含iOS8) 添加一下两个属性就行了 self.tableView.estimatedRowHeight = 44.0; self.tableView.rowHeight = UITableViewAutomaticDimension...(假设为宽100 高100) 水平居中 距离顶部距离(=10) 距离底部距离(>=10) 这样设置之后UITableViewAutomaticDimension就可以算出该cell的高度并正确显示,但是控制台老是报错误...,系统估算高度为120,就自己加了该约束,这样约束就多了,所以就报错了,怎样解决呢,又不能删除原有约束 这种情况约束的优先级(Priority)就起作用了,一般我们添加约束优先级默认都是1000,系统自己添加的这个约束也是...1000,我们只要降低我们自己view高度约束的优先级就行了,设置高度的约束优先级为750,这样当系统估算后添加估算高度后,我们自己设置的高度就不起作用了。

    2.4K30

    iOS坐标系探究

    *testLabel = [[UILabel alloc] initWithFrame:CGRectMake(0, 0, 100, 28)]; testLabel.text = @"测试文本"...所以按照UILabel.layer默认的坐标(0, 0),在左上角进行了绘制。 接着,我们尝试使用CoreText来渲染一段文本。...我们回顾下上文提到的两个渲染结果,我们产生如下疑问: UIGraphicsGetCurrentContext返回的是CGContext,代表着是左下角为原点的坐标系,用UILabel(UIKit坐标系)...因为渲染的view高度为100,所以这个坐标转换相当于把原点在左下角(0,100)的坐标系,转换为原点在左上角(0,0)的坐标系!...也可以按照坐标系变换的方式去理解,将左下角原点的坐标系相对y轴做一次垂直翻转,然后向上平移height的高度,这样得到左上角原点的坐标系。

    2.8K30

    Ios常用第三方框架(一)

    通过一个 UIScrollView 的扩展,可以轻松为 UIScrollView 的所有子类添加下拉刷新功能。...富文本 TFHpple- TFHpple 解析html的轻量级框架 RTLabel - RTLabel 基于UILabel类的拓展,能够支持Html标记的富文本显示,它是基于Core Text,因此也支持...FXLabel - FXLabel是一个功能强大使用简单的类库,通过提供一个子类改进了标准的UILabel组件,为字体增加了阴影、内阴影和渐变色等,可以被用在任何标准的UILabel中。...FXLabel还提供了更多控件,可以对字体行距、字体间距等进行调整。 WFReader - 一款简单的coretext阅读器,支持文本选择、高亮以及字体大小选择等。...HPGrowingTextView - HPGrowingTextView聊天输入文字,可以根据输入文字的多少自动改变输入框的高度。

    5.5K31

    iOS 性能优化

    如果你对文本显示没有特殊要求,可以参考下 UILabel 内部的实现方式:用 [NSAttributedString boundingRectWithSize:options:context:] 来计算文本宽高...常见的文本控件 (UILabel、UITextView 等),其排版和绘制都是在主线程进行的,当显示大量文本时,CPU 的压力会非常大。...尽管这实现起来非常麻烦,但其带来的优势也非常大,CoreText 对象创建好后,能直接获取文本的宽高等信息,避免了多次计算(调整 UILabel 大小时算一遍、UILabel 绘制时内部再算一遍);CoreText...CellLayout 包含所有文本的 CoreText 排版结果、Cell 内部每个控件的高度、Cell 的整体高度。...为了达到最高性能,你可能需要牺牲一些开发速度,不要用 Autolayout 等技术,少用 UILabel 等文本控件。

    2.9K20

    iOS UILabe及UIFont用法总结 原

    初始化一个UILabel对象,并初始化大小 UILabel * label = [[UILabel alloc]initWithFrame:CGRectMake(100, 100, 100, 100)...blueColor]; //设置是否高亮 label.highlighted=YES; 用户交互 默认关闭 label.userInteractionEnabled=NO; 是否有效,默认是YES,无效为灰色...label.enabled=NO; 显示的行数,0为无限 @property(nonatomic) NSInteger numberOfLines; 宽度自适应大小 默认是NO @property(nonatomic...@property(nonatomic) UIBaselineAdjustment baselineAdjustment; typedef enum {    //调整文本对应基线位置    UIBaselineAdjustmentAlignBaselines...,    //调整文本相对其边框的中心    UIBaselineAdjustmentAlignCenters,    //调整文本相对于边界的左上角 默认的    UIBaselineAdjustmentNone

    1K30

    UIButton实现各种图文结合的效果以及原理

    调整多少为最合适? 在调整之前我们先定义几个特定的变量值: : CGRect titleRect = titleLabel.frame; //文本控件在按钮中的frame值。...padding 我们可以通过更改按钮的titleEdgeInsets和imageEdgeInsets的值调整文本和图片的位置。...图片在左,文字在右,整体居中,设置间距 这种方式是按钮默认的图文布局方式,因为要调整图片和文本的间距,所以只需要文本右移padding/2而图片左移padding/2值就可以了。...而新的文本的顶部位置应该等于新的图片的顶部位置(selfHeight - totalHeight)/2 + 图片的高度imageRect.size.height + 间隔padding ,因此垂直需要偏移的值就是新的顶部值减去原来的顶部位置...而文本则要调整为距离顶部的间隔值,也就是新的文本的顶部值等于padding, 而原来顶部值是titleRect.origin.y,因此只需要偏移titleRect.origin.y - padding就可以了

    3K10

    iOS设置圆角及圆形图片

    方方正正的样式往往会显得很生硬,而圆角的样式会让人产生别样的亲切感,现在越来越多地用到圆角,诸如用户头像之类的图片也大都用圆形来显示,本文就介绍如何设置按钮、文本框的圆角以及制作圆形的图片。...对于圆形的头像,要制作正圆,我们需要首先设置UIImageView的高宽的一致的,然后我们设置其圆角角度为高度除以2即可,相当于90度,代码如下: // 圆形头像 UIImageView *avatarImgView...SCREENWIDTH - 75) / 2, 150, 75, 75)]; avatarImgView.image = [UIImage imageNamed:@"icon"]; // 图片做圆形,圆角角度为高度的一半...avatarImgView.frame.size.height / 2 ; [self.view addSubview:avatarImgView]; 对于第二个完全的半圆圆角,我们同样设置角度为高度的一般...,就可以显示边框了,然后同样设置圆角为4: // 带边框的圆角Label UILabel *label = [[UILabel alloc] initWithFrame:CGRectMake((SCREENWIDTH

    1.9K20
    领券