如何以UILabel缩小字体大小制作文本

时间:2010-04-21 18:55:57

标签: iphone objective-c cocoa-touch interface-builder

如果UILabel包含太多文字,我该如何设置我的标签以缩小字体大小?

以下是我设置UILabel的方法:

     descriptionLabel = [[UILabel alloc] initWithFrame:CGRectMake(200, 30, 130, 150)];
    [descriptionLabel setFont:[Utils getSystemFontWithSize:14]];
    [descriptionLabel setBackgroundColor:[UIColor clearColor]];
    [descriptionLabel setTextColor:[UIColor whiteColor]];
    descriptionLabel.numberOfLines = 1;
    [self addSubview:descriptionLabel];

4 个答案:

答案 0 :(得分:59)

descriptionLabel.adjustsFontSizeToFitWidth = YES;
descriptionLabel.minimumFontSize = 10.0; //adjust to preference obviously

以下示例在iPhone模拟器3.1.2上进行了测试和验证:

UILabel *descriptionLabel = [[UILabel alloc] initWithFrame:CGRectMake(90, 0, 200, 30)];

descriptionLabel.font = [UIFont systemFontOfSize:14.0];
descriptionLabel.minimumFontSize = 10.0;
descriptionLabel.adjustsFontSizeToFitWidth = YES;
descriptionLabel.numberOfLines = 1;
descriptionLabel.text = @"supercalifragilisticexpialidocious even thought he sound of it is something quite attrocious";

答案 1 :(得分:22)

要调整多行UILabel中的文本大小,您可以使用此辅助方法(基于11 Pixel Studios的code):

+ (void)resizeFontForLabel:(UILabel*)aLabel maxSize:(int)maxSize minSize:(int)minSize { 
 // use font from provided label so we don't lose color, style, etc
 UIFont *font = aLabel.font;

 // start with maxSize and keep reducing until it doesn't clip
 for(int i = maxSize; i >= minSize; i--) {
  font = [font fontWithSize:i];
  CGSize constraintSize = CGSizeMake(aLabel.frame.size.width, MAXFLOAT);

  // This step checks how tall the label would be with the desired font.
  CGSize labelSize = [aLabel.text sizeWithFont:font constrainedToSize:constraintSize lineBreakMode:UILineBreakModeWordWrap];
  if(labelSize.height <= aLabel.frame.size.height)
   break;
 }
 // Set the UILabel's font to the newly adjusted font.
 aLabel.font = font;
}

答案 2 :(得分:6)

答案 3 :(得分:0)

如果你想在需要时增加行数,可以使用Steve N的解决方案,if语句如下:

if(labelSize.height <= aLabel.frame.size.height)
{
  aLabel.numberOfLines = labelSize.height / font.lineHeight;

  break;
}