2010-05-04 3 views
36

Я хотел бы нарисовать содержимое переменной NSString в UIImage, но я понятия не имею, как это сделать. Мне нужно написать метод, который получит параметр NSString в качестве параметра и возвращает UIImage с текстом, нарисованным в нем.Как использовать функцию рисования NSString для создания UIImage из текста

ответ

88

Вы можете попробовать это: (обновляется прошивкой 4)

-(UIImage *)imageFromText:(NSString *)text 
{ 
    // set the font type and size 
    UIFont *font = [UIFont systemFontOfSize:20.0]; 
    CGSize size = [text sizeWithFont:font]; 

    // check if UIGraphicsBeginImageContextWithOptions is available (iOS is 4.0+) 
    if (UIGraphicsBeginImageContextWithOptions != NULL) 
     UIGraphicsBeginImageContextWithOptions(size,NO,0.0); 
    else 
     // iOS is < 4.0 
     UIGraphicsBeginImageContext(size); 

    // optional: add a shadow, to avoid clipping the shadow you should make the context size bigger 
    // 
    // CGContextRef ctx = UIGraphicsGetCurrentContext(); 
    // CGContextSetShadowWithColor(ctx, CGSizeMake(1.0, 1.0), 5.0, [[UIColor grayColor] CGColor]); 

    // draw in context, you can use also drawInRect:withFont: 
    [text drawAtPoint:CGPointMake(0.0, 0.0) withFont:font]; 

    // transfer image 
    UIImage *image = UIGraphicsGetImageFromCurrentImageContext(); 
    UIGraphicsEndImageContext();  

    return image; 
} 

Для вызова :

UIImage *image = [self imageFromText:@"This is a text"]; 
+7

для iOS4 + вы должны создать контекст с масштабированием 0.0, чтобы получить масштабирование основного экрана, если масштабирование не равно 1.0 (отображение сетчатки равно 2.0): \t UIGraphicsBeginImageContextWithOptions (размер, НЕТ, 0.0); – valexa

+0

@rpmx escape-символы, такие как \ n новая строка не распознаются ?? – Yadnesh

+0

@Yadnesh: Используйте: [текст drawInRect: (CGRect) rect withFont: (шрифт UIFont *)]; – rpmx

2

Begin контекст изображения с UIGraphicsBeginImageContext, привлечь к нему, получить изображение с UIGraphicsGetImageFromCurrentImageContext, в конце его UIGraphicsEndImageContext

+0

Как нарисовать NSString? Это то, о чем я спрашивал. ПОЖАЛУЙСТА! – Jaba

+0

Посмотрите на NSString UIKit Дополнения - доступно несколько функций рисования nsstring - например, drawAtPoint: withFont: 'или' drawInRect: withFont: 'и другие – Vladimir

+0

@Jaba: посмотрите 'CGContextShowTextAtPoint' и связанные с ним функции. – 2010-05-04 14:20:30

13

Добавление Swift версии, а также дает вам больше возможностей:

class func sizeOfAttributeString(str: NSAttributedString, maxWidth: CGFloat) -> CGSize { 
    let size = str.boundingRectWithSize(CGSizeMake(maxWidth, 1000), options:(NSStringDrawingOptions.UsesLineFragmentOrigin), context:nil).size 
    return size 
} 

class func imageFromText(text:NSString, font:UIFont, maxWidth:CGFloat, color:UIColor) -> UIImage { 
    let paragraph = NSMutableParagraphStyle() 
    paragraph.lineBreakMode = NSLineBreakMode.ByWordWrapping 
    paragraph.alignment = .Center // potentially this can be an input param too, but i guess in most use cases we want center align 

    let attributedString = NSAttributedString(string: text, attributes: [NSFontAttributeName: font, NSForegroundColorAttributeName: color, NSParagraphStyleAttributeName:paragraph]) 

    let size = sizeOfAttributeString(attributedString, maxWidth: maxWidth) 
    UIGraphicsBeginImageContextWithOptions(size, false , 0.0) 
    attributedString.drawInRect(CGRectMake(0, 0, size.width, size.height)) 
    let image = UIGraphicsGetImageFromCurrentImageContext() 
    UIGraphicsEndImageContext() 
    return image 
} 
0

Swift 3,1

func sizeOfAttributeString(str: NSAttributedString, maxWidth: CGFloat) -> CGSize { 
    let size = str.boundingRect(with: CGSize(width: maxWidth, height: 1000), options:(NSStringDrawingOptions.usesLineFragmentOrigin), context:nil).size 
    return size 
} 

func imageFromText(text:NSString, font:UIFont, maxWidth:CGFloat, color:UIColor) -> UIImage { 
    let paragraph = NSMutableParagraphStyle() 
    paragraph.lineBreakMode = NSLineBreakMode.byWordWrapping 
    paragraph.alignment = .center 

    let attributedString = NSAttributedString(string: text as String, attributes: [NSFontAttributeName: font, NSForegroundColorAttributeName: color, NSParagraphStyleAttributeName:paragraph]) 

    let size = sizeOfAttributeString(str: attributedString, maxWidth: maxWidth) 
    UIGraphicsBeginImageContextWithOptions(size, false , 0.0) 
    attributedString.draw(in: CGRect(x: 0, y: 0, width: size.width, height: size.height)) 
    let image = UIGraphicsGetImageFromCurrentImageContext() 
    UIGraphicsEndImageContext() 
    return image! 
} 

Заслуга Бао Лэй за красивый ответ.