uilabel 和uitextview 自适应大小

 

本文转载至 http://blog.csdn.net/liulichao20/article/details/8957752

分类: ios   321人阅读  评论(0)  收藏  举报

 //UILabel自动换行,自适应高度

    UILabel *label = [[UILabel alloc] initWithFrame:CGRectZero];

    [label setBackgroundColor:[UIColor clearColor]];

    [label setFont:[UIFont systemFontOfSize:14]];

    [label setLineBreakMode:UILineBreakModeWordWrap];

    [label setNumberOfLines:0];

    [self.view addSubview:label];

    

    NSString *str = @" fsdfadsfdsfsdfads  fdsfads水电费 水电费水电费水电费水电费水电费水电费水电费水电费水电费 水电费水电费水电费 水电费时代fsdf ";

    CGSize size = [str sizeWithFont:[UIFont systemFontOfSize:14]constrainedToSize:CGSizeMake(320,500) lineBreakMode:UILineBreakModeWordWrap];

    [label setText:str];

    [label setFrame:CGRectMake(0.0f, 20.0f, 300, size.height)];

    [label release];

    

    //UITextView自动换行,自适应高度

    UITextView *textView = [[UITextView alloc] initWithFrame:CGRectMake(0, 150, 320,240)];

    textView.backgroundColor = [UIColor clearColor];

    textView.text = str;

    textView.scrollEnabled = YES;

    textView.font = [UIFont systemFontOfSize:14];

    textView.userInteractionEnabled = NO;

    textView.autoresizingMask = UIViewAutoresizingFlexibleHeight;

    [self.view addSubview:textView];

 

本文转载至  http://tangchuanyao.com/20120507760/

自动调整UITextView/UILabel的高度height

很多时候都需要依据用户输入的内容自动调整UILabel/UITextView的高度和宽度,特别是UINavigationController的标题,超过一行的时候默认就是「…」我们希望他能换行表示,这样就需要根据内容调整titleView的高度啦。直接贴sample代码,高度和宽度可以根据自己的需要调整。

UILabel Sample code

?
1
2
3
4
5
6
7
CGRect frame = CGRectMake(20, 0, 280,44);
CGSize labelsize = [titleLabel.text sizeWithFont:[UIFont boldSystemFontOfSize: 16.0f]
                    constrainedToSize:CGSizeMake(320, 44)
                        lineBreakMode:UILineBreakModeTailTruncation];
frame.size.width = labelsize.width;
frame.size.height = labelsize.height;
titleLabel.frame = frame;

UITextView Sample code

?
1
2
3
4
5
6
CGRect frame = noteTextView.frame;
CGSize size = [noteTextView.text sizeWithFont:noteTextView.font
                         constrainedToSize:CGSizeMake(280, 1000)
                             lineBreakMode:UILineBreakModeTailTruncation];
frame.size.height = size.height > 1 ? size.height + 20 : 64;
noteTextView.frame = frame;

UITextView是UIScrollView的子类,因此有contentSize属性,也可以按如下实现

?
1
2
3
CGRect frame = noteTextView.frame;
frame.size.height = noteTextView.contentSize.height;
noteTextView.frame = frame;

 

本文转载至   http://blog.sina.com.cn/s/blog_759d3e120101alji.html

苹果API

UILineBreakMode

Options for wrapping and truncating text. (Deprecated. Use NSLineBreakMode instead.)

typedef enum { 
   UILineBreakModeWordWrap = 0, 
   UILineBreakModeCharacterWrap, 
   UILineBreakModeClip, 
   UILineBreakModeHeadTruncation, 
   UILineBreakModeTailTruncation, 
   UILineBreakModeMiddleTruncation, 
} UILineBreakMode;

NSLineBreakMode

These constants specify what happens when a line is too long for its container.

enum {
   NSLineBreakByWordWrapping = 0,
   NSLineBreakByCharWrapping,
   NSLineBreakByClipping,
   NSLineBreakByTruncatingHead,
   NSLineBreakByTruncatingTail,
   NSLineBreakByTruncatingMiddle
};
typedef NSUInteger NSLineBreakMode


 

lineBreak模式在6.0之前一直用UILineBreakMode枚举类型,6.0使用NSLineBreakMode枚举类型。枚举值中各个值的意义,解释如下:

   UILineBreakModeWordWrap = 0, 
   以单词为单位换行,以单位为单位截断。 
   UILineBreakModeCharacterWrap, 
   以字符为单位换行,以字符为单位截断。 
   UILineBreakModeClip, 
   以单词为单位换行。以字符为单位截断。 
   UILineBreakModeHeadTruncation, 
   以单词为单位换行。如果是单行,则开始部分有省略号。如果是多行,则中间有省略号,省略号后面有4个字符。 
   UILineBreakModeTailTruncation, 
   以单词为单位换行。无论是单行还是多行,都是末尾有省略号。 
   UILineBreakModeMiddleTruncation, 
   以单词为单位换行。无论是单行还是多行,都是中间有省略号,省略号后面只有2个字符。      

 

转载于:https://www.cnblogs.com/Camier-myNiuer/p/3424483.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: UILabel 高度自适应是指根据文本内容的多少自动调整UILabel的高度,使得文本能够完整显示并且没有截断。在Swift中,可以通过以下几个步骤来实现UILabel的高度自适应。 1. 设置UILabel的numberOfLines属性为0,表示文本可以显示多行。 ``` label.numberOfLines = 0 ``` 2. 设置UILabel的preferredMaxLayoutWidth属性为UILabel的宽度,确保文本能够根据UILabel的宽度进行换行。 ``` label.preferredMaxLayoutWidth = label.frame.width ``` 3. 根据文本内容和UILabel的宽度计算出合适的UILabel高度。可以通过UILabel的text属性获取文本内容,再利用boundingRect方法计算出文本所占据的空间。 ``` let text = label.text ?? "" let size = CGSize(width: label.frame.width, height: .greatestFiniteMagnitude) let options = NSStringDrawingOptions.usesFontLeading.union(.usesLineFragmentOrigin) let attributes = [NSAttributedString.Key.font: label.font] let boundingRect = text.boundingRect(with: size, options: options, attributes: attributes, context: nil) let height = ceil(boundingRect.height) ``` 4. 更新UILabel的frame属性,将高度设置为计算出的合适高度。 ``` label.frame.size.height = height ``` 通过以上步骤,我们就可以实现UILabel的高度自适应。当文本内容改变时,只需要重新计算高度并更新UILabel的frame即可。这样就能确保UILabel始终能够完整显示文本内容,而不会出现截断。 ### 回答2: 在Swift中,可以通过以下步骤实现UILabel的高度自适应: 1. 首先,我们需要将UILabel的numberOfLines属性设置为0,表示可以显示任意行数的文本。 ```swift label.numberOfLines = 0 ``` 2. 接下来,需要设置UILabel的宽度约束,即限制UILabel的宽度,以便计算文本在给定宽度下的高度。 ```swift label.widthAnchor.constraint(equalToConstant: desiredWidth).isActive = true ``` 3. 然后,使用UILabel的text属性来设置要显示的文本内容。 ```swift label.text = "这是要显示的文本内容" ``` 4. 最后,在对UILabel的布局进行更新之后,我们需要调用UILabel的sizeToFit()方法来计算并适应UILabel的高度。 ```swift label.sizeToFit() ``` 完成这些步骤后,UILabel将根据显示的文本内容自动调整高度,以适应所设置的宽度约束。 需要注意的是,当UILabel的文本过长时,自适应的高度可能会导致UILabel的宽度变窄,以保持文本的显示完整性。 ### 回答3: UILabel 在 Swift 中可以通过使用 `sizeToFit()` 方法来实现高度自适应。 sizeToFit() 方法用于根据UILabel中的文本内容调整其大小,以确保文本内容不被截断。当调用这个方法时,UILabel会根据当前设置的字体、文本内容和自动布局约束来自动计算并调整其大小。 首先,创建一个UILabel对象,并设置其属性,比如文本内容、字体大小和布局约束。 ```swift let label = UILabel() label.text = "这是一个需要自适应高度的UILabel" label.font = UIFont.systemFont(ofSize: 16) label.numberOfLines = 0 // 设置为0表示自动换行 // 设置UILabel的宽度约束 let maxWidth = UIScreen.main.bounds.width - 20 // 假设UILabel的最大宽度是屏幕宽度减去左右边距 label.widthAnchor.constraint(lessThanOrEqualToConstant: maxWidth).isActive = true ``` 接下来,调用`sizeToFit()`方法来自动计算并调整UILabel大小。 ```swift label.sizeToFit() ``` 通过以上代码,UILabel的高度会根据文本内容自动计算并调整,确保文本不会被截断。UILabel会根据字体大小和布局约束,自动计算所需的高度。 最后,可以通过如下代码将UILabel添加到父视图中。 ```swift parentView.addSubview(label) ``` 这样,UILabel就会根据文本内容自动调整高度,并显示在父视图中。 通过使用以上的方法,就可以实现UILabel的高度自适应功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值