以下の方法で試すことができます。次の属性を使用して、UIView の右下隅にテキストを描画するのに役立ちます。
- NSFontAttributeName - サイズ付きのフォント名
- NSStrokeWidthAttributeName - ストローク幅
- NSStrokeColorAttributeName - テキストの色
Objective-C - UIView にテキストを描画し、UIImage として返します。
-(UIImage *) imageWithView:(UIView *)view text:(NSString *)text {
UIGraphicsBeginImageContextWithOptions(view.bounds.size, view.opaque, 0.0);
[view.layer renderInContext:UIGraphicsGetCurrentContext()];
// Setup the font specific variables
NSDictionary *attributes = @{
NSFontAttributeName : [UIFont fontWithName:@"Helvetica" size:12],
NSStrokeWidthAttributeName : @(0),
NSStrokeColorAttributeName : [UIColor blackColor]
};
// Draw text with CGPoint and attributes
[text drawAtPoint:CGPointMake(view.frame.origin.x+10 , view.frame.size.height-25) withAttributes:attributes];
UIImage * img = UIGraphicsGetImageFromCurrentImageContext();
UIGraphicsEndImageContext();
return img;
}`
Swift - UIView にテキストを描画し、UIImage として返します。
func imageWithView(view : UIView, text : NSString) -> UIImage {
UIGraphicsBeginImageContextWithOptions(view.bounds.size, view.opaque, 0.0);
view.layer.renderInContext(UIGraphicsGetCurrentContext()!);
// Setup the font specific variables
let attributes :[String:AnyObject] = [
NSFontAttributeName : UIFont(name: "Helvetica", size: 12)!,
NSStrokeWidthAttributeName : 0,
NSForegroundColorAttributeName : UIColor.blackColor()
]
// Draw text with CGPoint and attributes
text.drawAtPoint(CGPointMake(view.frame.origin.x+10, view.frame.size.height-25), withAttributes: attributes);
let img:UIImage = UIGraphicsGetImageFromCurrentImageContext();
UIGraphicsEndImageContext();
return img;
}`