UILabel的属性总结

  1. #import "ViewController.h"  
  2. #import <CoreText/CoreText.h>  
  3.   
  4. @interface ViewController ()  
  5.   
  6. @end  
  7.   
  8. @implementation ViewController  
  9.   
  10. - (void)viewDidLoad  
  11. {  
  12.     [super viewDidLoad];  
  13.     //学习内容  
  14.     /* 
  15.      1.控件 UIView UILabel UITextField UITextView UIButton 
  16.      2.字体、大小、单位、颜色 
  17.      */  
  18.     UILabel *label = [[UILabel alloc] initWithFrame:CGRectMake(1030300260)];  
  19.     label.text = @"Label Text Content, This is a text label things attribute";//默认为空  
  20.     label.font = [UIFont systemFontOfSize:17];//默认使用系统的17  
  21.     label.textColor = [UIColor orangeColor];//默认使用文本黑色  
  22.     label.shadowColor = [UIColor lightGrayColor];//默认没有阴影  
  23.     label.shadowOffset = CGSizeMake(1,0);//默认是一个向上的阴影(0,-1)  
  24.     label.textAlignment = NSTextAlignmentCenter;//默认是左对齐  
  25.     label.lineBreakMode = NSLineBreakByTruncatingTail;//段落样式,默认是最后截断尾巴,用...代替  
  26.       
  27.     //富文本的基本数据类型,属性字符串。以此为基础,如果这个设置了相应的属性,则会忽略上面设置的属性,默认为空  
  28.     NSString *string = label.text;  
  29.     const CGFloat fontSize = 16.0;  
  30.     NSMutableAttributedString *attrString = [[NSMutableAttributedString alloc] initWithString:string];  
  31.     NSUInteger length = [string length];  
  32.     //设置字体  
  33.     UIFont *baseFont = [UIFont systemFontOfSize:fontSize];  
  34.     [attrString addAttribute:NSFontAttributeName value:baseFont range:NSMakeRange(0, length)];//设置所有的字体  
  35.     UIFont *boldFont = [UIFont boldSystemFontOfSize:fontSize];  
  36.     [attrString addAttribute:NSFontAttributeName value:boldFont range:[string rangeOfString:@"Text"]];//设置Text这四个字母的字体为粗体  
  37.     //设置倾斜,需要导入coreText  
  38.     UIFont *italicFont = GetVariationOfFontWithTrait(baseFont,  
  39.                                                      kCTFontTraitItalic);  
  40.     [attrString addAttribute:NSFontAttributeName value:italicFont  
  41.                        range:[string rangeOfString:@"Label"]];  
  42.     // 设置颜色  
  43.     UIColor *color = [UIColor redColor];  
  44.     [attrString addAttribute:NSForegroundColorAttributeName  
  45.                        value:color  
  46.                        range:[string rangeOfString:@"Content"]];  
  47.     [attrString addAttribute:NSBackgroundColorAttributeName value:[UIColor blueColor] range:[string rangeOfString:@"ent"]];  
  48.       
  49.     //可以对这些属性设置值  
  50.     //字体名称有以下:  
  51. //    label.font = [UIFont fontWithName:@"Arial-BoldItalicMT" size:24];  
  52.     [attrString addAttribute:NSFontAttributeName value:[UIFont fontWithName:@"Verdana-BoldItalic" size:18] range:[string rangeOfString:@"Label"]];  
  53.     label.numberOfLines = 2;  
  54.     NSMutableParagraphStyle *  
  55.     style = [[NSParagraphStyle defaultParagraphStyle] mutableCopy];  
  56.     style.lineSpacing = 10;//增加行高  
  57.     style.headIndent = 10;//头部缩进,相当于左padding  
  58.     style.tailIndent = -10;//相当于右padding  
  59.     style.lineHeightMultiple = 1.5;//行间距是多少倍  
  60.     style.alignment = NSTextAlignmentLeft;//对齐方式  
  61.     style.firstLineHeadIndent = 20;//首行头缩进  
  62.     style.paragraphSpacing = 10;//段落后面的间距  
  63.     style.paragraphSpacingBefore = 20;//段落之前的间距  
  64.     [attrString addAttribute:NSParagraphStyleAttributeName value:style range:NSMakeRange(0, length)];  
  65.       
  66.     [attrString addAttribute:NSKernAttributeName value:@2 range:NSMakeRange(0, length)];//字符间距 2pt  
  67.     [attrString addAttribute:NSStrokeColorAttributeName value:[UIColor blueColor] range:[string rangeOfString:@"is"]];//设置文字描边颜色,需要和NSStrokeWidthAttributeName设置描边宽度,这样就能使文字空心  
  68.     [attrString addAttribute:NSStrokeWidthAttributeName value:@2 range:[string rangeOfString:@"is"]];//空心字,文字边框描述  
  69.     [attrString addAttribute:NSUnderlineStyleAttributeName value:@(NSUnderlineStyleSingle) range:[string rangeOfString:@"text"]];//下划线  
  70.     [attrString addAttribute:NSUnderlineStyleAttributeName value:@(NSUnderlineStyleThick) range:[string rangeOfString:@"label"]];//厚的下划线  
  71.     [attrString addAttribute:NSStrikethroughStyleAttributeName value:@(NSUnderlinePatternSolid | NSUnderlineStyleSingle) range:[string rangeOfString:@"things"]];//删除线  
  72.     [attrString addAttribute:NSStrikethroughColorAttributeName value:[UIColor blueColor] range:[string rangeOfString:@"things"]];//删除线蓝色  
  73.    label.attributedText = attrString;  
  74.       
  75.     label.highlightedTextColor = [UIColor redColor];//设置文本高亮显示颜色,与highlighted一起使用。  
  76.     label.highlighted = NO; //高亮状态是否打开  
  77.     label.enabled = YES;//设置文字内容是否可变  
  78.     label.userInteractionEnabled = YES;//设置标签是否忽略或移除用户交互。默认为NO  
  79.     label.baselineAdjustment = UIBaselineAdjustmentNone;//如果adjustsFontSizeToFitWidth属性设置为YES,这个属性就来控制文本基线的行为。  
  80. //    UIBaselineAdjustmentAlignBaselines=0,默认,文本最上端与中线对齐。  
  81. //    UIBaselineAdjustmentAlignCenters,   文本中线与label中线对齐。  
  82. //    UIBaselineAdjustmentNone,  文本最低端与label中线对齐。;  
  83.     [self.view addSubview:label];  
  84.       
  85.     /* 
  86.      字体名如下: 
  87.      Font Family: American Typewriter 
  88.      Font: AmericanTypewriter 
  89.      Font: AmericanTypewriter-Bold 
  90.       
  91.      Font Family: AppleGothic 
  92.      Font: AppleGothic 
  93.       
  94.      Font Family: Arial 
  95.      Font: ArialMT 
  96.      Font: Arial-BoldMT 
  97.      Font: Arial-BoldItalicMT 
  98.      Font: Arial-ItalicMT 
  99.       
  100.      Font Family: Arial Rounded MT Bold 
  101.      Font: ArialRoundedMTBold 
  102.       
  103.      Font Family: Arial Unicode MS 
  104.      Font: ArialUnicodeMS 
  105.       
  106.      Font Family: Courier 
  107.      Font: Courier 
  108.      Font: Courier-BoldOblique 
  109.      Font: Courier-Oblique 
  110.      Font: Courier-Bold 
  111.       
  112.      Font Family: Courier New 
  113.      Font: CourierNewPS-BoldMT 
  114.      Font: CourierNewPS-ItalicMT 
  115.      Font: CourierNewPS-BoldItalicMT 
  116.      Font: CourierNewPSMT 
  117.       
  118.      Font Family: DB LCD Temp 
  119.      Font: DBLCDTempBlack 
  120.       
  121.      Font Family: Georgia 
  122.      Font: Georgia-Bold 
  123.      Font: Georgia 
  124.      Font: Georgia-BoldItalic 
  125.      Font: Georgia-Italic 
  126.       
  127.      Font Family: Helvetica 
  128.      Font: Helvetica-Oblique 
  129.      Font: Helvetica-BoldOblique 
  130.      Font: Helvetica 
  131.      Font: Helvetica-Bold 
  132.       
  133.      Font Family: Helvetica Neue 
  134.      Font: HelveticaNeue 
  135.      Font: HelveticaNeue-Bold 
  136.       
  137.      Font Family: Hiragino Kaku Gothic **** W3 
  138.      Font: HiraKakuProN-W3 
  139.       
  140.      Font Family: Hiragino Kaku Gothic **** W6 
  141.      Font: HiraKakuProN-W6 
  142.       
  143.      Font Family: Marker Felt 
  144.      Font: MarkerFelt-Thin 
  145.       
  146.      Font Family: STHeiti J 
  147.      Font: STHeitiJ-Medium 
  148.      Font: STHeitiJ-Light 
  149.       
  150.      Font Family: STHeiti K 
  151.      Font: STHeitiK-Medium 
  152.      Font: STHeitiK-Light 
  153.       
  154.      Font Family: STHeiti SC 
  155.      Font: STHeitiSC-Medium 
  156.      Font: STHeitiSC-Light 
  157.       
  158.      Font Family: STHeiti TC 
  159.      Font: STHeitiTC-Light 
  160.      Font: STHeitiTC-Medium 
  161.       
  162.      Font Family: Times New Roman 
  163.      Font: TimesNewRomanPSMT 
  164.      Font: TimesNewRomanPS-BoldMT 
  165.      Font: TimesNewRomanPS-BoldItalicMT 
  166.      Font: TimesNewRomanPS-ItalicMT 
  167.       
  168.      Font Family: Trebuchet MS 
  169.      Font: TrebuchetMS-Italic 
  170.      Font: TrebuchetMS 
  171.      Font: Trebuchet-BoldItalic 
  172.      Font: TrebuchetMS-Bold 
  173.       
  174.      Font Family: Verdana 
  175.      Font: Verdana-Bold 
  176.      Font: Verdana-BoldItalic 
  177.      Font: Verdana 
  178.      Font: Verdana-Italic 
  179.       
  180.      Font Family: Zapfino 
  181.      Font: Zapfino 
  182.      */  
  183.       
  184.     //文本对齐方式  
  185.     /* Values for NSTextAlignment */  
  186.     /* 
  187.     NSTextAlignmentLeft 左对齐 
  188.     NSTextAlignmentCenter 剧中对齐 
  189.     NSTextAlignmentRight 右对齐 
  190.     NSTextAlignmentJustified 两端对齐 
  191.     NSTextAlignmentNatural 根据显示的文字特性对齐 
  192.     */  
  193.       
  194.     //段落样式  
  195.     /* 
  196.     lineSpacing;                         来增加行距 
  197.     paragraphSpacing; 
  198.     alignment;                           对齐 
  199.     firstLineHeadIndent;                 段落开始的缩排像素 
  200.     headIndent;                          可调整全部文字的缩排距离,可当作左边 padding 使用 
  201.     tailIndent;                          可调整文字尾端的缩排距离。需要注意的是,这里指定的值可以当作文字显示的宽、而也可当作右边 padding 使用,依据输入的正负值而定: 
  202.     lineBreakMode; 
  203.     minimumLineHeight; 
  204.     maximumLineHeight;        而针对不同的字型与字号,我们可以透过指定最大与最小行距(maximumLineHeight 与 minimumLineHeight)来避免过高或过窄的状况发生。 
  205.     baseWritingDirection; 
  206.     lineHeightMultiple;                  想要调整行距,可以透过搭配使用 lineHeightMultiple 更改行距倍数 
  207.     paragraphSpacingBefore; 而若是文章内容有分段落的话,也可以透过指定段落结尾距离(paragraphSpacing)以及段落开头距离(paragraphSpacingBefore): 
  208.     hyphenationFactor; 
  209.         @property(readwrite,copy,NS_NONATOMIC_IOSONLY) NSArray *tabStops NS_AVAILABLE_IOS(7_0); 
  210.         @property(readwrite,NS_NONATOMIC_IOSONLY) CGFloat defaultTabInterval NS_AVAILABLE_IOS(7_0); 
  211.      */  
  212.       
  213.     /* Predefined character attributes for text. If the key is not in the dictionary, then use the default values as described below.  //预定义的文本属性值,如果键不是一个字典,那么使用默认的值作为以下描述 
  214.      NSFontAttributeName 字体 默认是Helvetica 12号 
  215.      NSParagraphStyleAttributeName 段落样式 
  216.      */  
  217.     /* 
  218.     UIKIT_EXTERN NSString *const  NS_AVAILABLE_IOS(6_0);      // NSParagraphStyle, default defaultParagraphStyle 
  219.     UIKIT_EXTERN NSString *const NSForegroundColorAttributeName NS_AVAILABLE_IOS(6_0);     // UIColor, default blackColor 
  220.     UIKIT_EXTERN NSString *const NSBackgroundColorAttributeName NS_AVAILABLE_IOS(6_0);     // UIColor, default nil: no background 
  221.     UIKIT_EXTERN NSString *const NSLigatureAttributeName NS_AVAILABLE_IOS(6_0);            // NSNumber containing integer, default 1: default ligatures, 0: no ligatures 
  222.     UIKIT_EXTERN NSString *const NSKernAttributeName NS_AVAILABLE_IOS(6_0);                // NSNumber containing floating point value, in points; amount to modify default kerning. 0 means kerning is disabled. (note: values other than nil and 0 are unsupported on iOS) 
  223.     UIKIT_EXTERN NSString *const NSStrikethroughStyleAttributeName NS_AVAILABLE_IOS(6_0);  // NSNumber containing integer, default 0: no strikethrough 
  224.     UIKIT_EXTERN NSString *const NSUnderlineStyleAttributeName NS_AVAILABLE_IOS(6_0);      // NSNumber containing integer, default 0: no underline 
  225.     UIKIT_EXTERN NSString *const NSStrokeColorAttributeName NS_AVAILABLE_IOS(6_0);         // UIColor, default nil: same as foreground color 
  226.     UIKIT_EXTERN NSString *const NSStrokeWidthAttributeName NS_AVAILABLE_IOS(6_0);         // NSNumber containing floating point value, in percent of font point size, default 0: no stroke; positive for stroke alone, negative for stroke and fill (a typical value for outlined text would be 3.0) 
  227.     UIKIT_EXTERN NSString *const NSShadowAttributeName NS_AVAILABLE_IOS(6_0);              // NSShadow, default nil: no shadow 
  228.     UIKIT_EXTERN NSString *const NSTextEffectAttributeName NS_AVAILABLE_IOS(7_0);          // NSString, default nil: no text effect 
  229.  
  230.     UIKIT_EXTERN NSString *const NSAttachmentAttributeName NS_AVAILABLE_IOS(7_0);          // NSTextAttachment, default nil 
  231.     UIKIT_EXTERN NSString *const NSLinkAttributeName NS_AVAILABLE_IOS(7_0);                // NSURL (preferred) or NSString 
  232.     UIKIT_EXTERN NSString *const NSBaselineOffsetAttributeName NS_AVAILABLE_IOS(7_0);      // NSNumber containing floating point value, in points; offset from baseline, default 0 
  233.     UIKIT_EXTERN NSString *const NSUnderlineColorAttributeName NS_AVAILABLE_IOS(7_0);      // UIColor, default nil: same as foreground color 
  234.     UIKIT_EXTERN NSString *const NSStrikethroughColorAttributeName NS_AVAILABLE_IOS(7_0);  // UIColor, default nil: same as foreground color 
  235.     UIKIT_EXTERN NSString *const NSObliquenessAttributeName NS_AVAILABLE_IOS(7_0);         // NSNumber containing floating point value; skew to be applied to glyphs, default 0: no skew 
  236.     UIKIT_EXTERN NSString *const NSExpansionAttributeName NS_AVAILABLE_IOS(7_0);           // NSNumber containing floating point value; log of expansion factor to be applied to glyphs, default 0: no expansion 
  237.  
  238.     UIKIT_EXTERN NSString *const NSWritingDirectionAttributeName NS_AVAILABLE_IOS(7_0);    // NSArray of NSNumbers representing the nested levels of writing direction overrides as defined by Unicode LRE, RLE, LRO, and RLO characters.  The control characters can be obtained by masking NSWritingDirection and NSTextWritingDirection values.  LRE: NSWritingDirectionLeftToRight|NSTextWritingDirectionEmbedding, RLE: NSWritingDirectionRightToLeft|NSTextWritingDirectionEmbedding, LRO: NSWritingDirectionLeftToRight|NSTextWritingDirectionOverride, RLO: NSWritingDirectionRightToLeft|NSTextWritingDirectionOverride, 
  239.  
  240.     UIKIT_EXTERN NSString *const NSVerticalGlyphFormAttributeName NS_AVAILABLE_IOS(6_0);   // An NSNumber containing an integer value.  0 means horizontal text.  1 indicates vertical text.  If not specified, it could follow higher-level vertical orientation settings.  Currently on iOS, it's always horizontal.  The behavior for any other value is undefined. 
  241.      */  
  242.       
  243.     // NSParagraphStyle  段落样式  
  244. //    typedef NS_ENUM(NSInteger, NSLineBreakMode) {     /* What to do with long lines */ //对于长内容或多行内容的处理方式  
  245. //        NSLineBreakByWordWrapping = 0,        /* Wrap at word boundaries, default */   //按包含单词为界限截断  
  246. //        NSLineBreakByCharWrapping,        /* Wrap at character boundaries */           //按字符为界限截断  
  247. //        NSLineBreakByClipping,        /* Simply clip */                                //简单的修剪  
  248. //        NSLineBreakByTruncatingHead,  /* Truncate at head of line: "...wxyz" */        //截断头部  
  249. //        NSLineBreakByTruncatingTail,  /* Truncate at tail of line: "abcd..." */        //截断尾巴  
  250. //        NSLineBreakByTruncatingMiddle /* Truncate middle of line:  "ab...yz" */        //截断中间  
  251. //    } NS_ENUM_AVAILABLE_IOS(6_0);  
  252. }  
  253. //获取斜体  
  254. UIFont * GetVariationOfFontWithTrait(UIFont *baseFont,  
  255.                                      CTFontSymbolicTraits trait) {  
  256.     CGFloat fontSize = [baseFont pointSize];  
  257.     CFStringRef  
  258.     baseFontName = (__bridge CFStringRef)[baseFont fontName];  
  259.     CTFontRef baseCTFont = CTFontCreateWithName(baseFontName,  
  260.                                                 fontSize, NULL);  
  261.     CTFontRef ctFont =  
  262.     CTFontCreateCopyWithSymbolicTraits(baseCTFont, 0, NULL,  
  263.                                        trait, trait);  
  264.     NSString *variantFontName =  
  265.     CFBridgingRelease(CTFontCopyName(ctFont,  
  266.                                      kCTFontPostScriptNameKey));  
  267.   
  268.     UIFont *variantFont = [UIFont fontWithName:variantFontName  
  269.                                           size:fontSize];  
  270.     CFRelease(ctFont);  
  271.     CFRelease(baseCTFont);  
  272.     return variantFont;  
  273. };  
  274.   
  275.   
  276. - (void)didReceiveMemoryWarning  
  277. {  
  278.     [super didReceiveMemoryWarning];  
  279.     // Dispose of any resources that can be recreated.  
  280. }  
  281.   
  282. @end  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值