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

iOS 段落富文本使用相关推荐

  1. iOS之富文本(二)

    之前做项目时遇到一个问题: 使用UITextView显示一段电影的简介,由于字数比较多,所以字体设置的很小,行间距和段间距也很小,一大段文字挤在一起看起来很别扭,想要把行间距调大,结果在XCode中查 ...

  2. ios开发 html编辑器,iOS实现富文本编辑器的方法详解

    前言 富文本编辑器不同于文本编辑器,国内做的比较好的比如有百度的UEditor和kindEditor.但是这两个也有它的缺点:界面过于复杂.不够简洁.UI设计也比较落后.不够轻量化,这篇文章我们将给大 ...

  3. ios html富文本分页,富文本框与分页

    1.富文本框javascript UEditor, CKEditor,wangEditor 市面用得比较多的富文本框html 使用是的wangEditor,要学习的话能够去看它的官网 -> ht ...

  4. iOS设置富文本行间距、字间距

    Demo下载地址 我们在展示文字信息时,经常会碰到换行自适应高度的文本,这时我们会发现换行之后,文本之间的行间距依然很小,导致看起来很拥挤,影响美观.因此以下代码就是来解决这些问题,新建一个NSStr ...

  5. ios html富文本带图片,iOS 富文本文字添加图片

    如图:标题前面添加海外直邮和跨境保税,iOS最好使用富文本添加图片附件的方法 NSTextAttachment*textAttachment = [[NSTextAttachment alloc] i ...

  6. iOS 富文本风格NSMutableParagraphStyle、定制UITextView插入图片和定制复制

    问题一 开发过程中,经常会遇到动态计算行高的问题, - (CGRect)boundingRectWithSize:(CGSize)size options:(NSStringDrawingOption ...

  7. iOS - 富文本AttributedString

    最近项目中用到了图文混排,所以就研究了一下iOS中的富文本,打算把研究的结果分享一下,也是对自己学习的一个总结. 在iOS中或者Mac OS X中怎样才能将一个字符串绘制到屏幕上呢? 简单来说,是通过 ...

  8. iOS自己总结的超级详细分解富文本大全(AttributedString),图文混排很轻松

    前言 最近项目中对图文混排有一定的需求,例如价格,文字链接,文字颜色变化等要求,翻了很多资料,咱们对这些属性做了如下的总结,希望能在方便自己查阅! NSFontAttributeName 设置字体大小 ...

  9. iOS开发- OC之富文本

    之前做项目时遇到一个问题: 使用UITextView显示一段电影的简介,由于字数比较多,所以字体设置的很小,行间距和段间距也很小,一大段文字挤在一起看起来很别扭,想要把行间距调大,结果在XCode中查 ...

最新文章

  1. 【linux】Matchbox(二):基本概念
  2. 致力协同办公oa系统服务器设置,致力协同办公oa系统安装手册新.pdf
  3. SpringBoot_数据访问-整合Druid配置数据源监控
  4. 矫情这一次,感谢这几个人。
  5. 从网上看到的很搞笑的东西
  6. 计算机相近专业有哪些,计算机相关的专业有哪些
  7. android:configchanges的作用,将uiMode附加到android:configChanges实际做什么?
  8. Modbus通信协议 【 初识 Modbus】
  9. 猫工智能:卷积神经网络层的实现
  10. 计算机管理模糊,电脑显示器显示有点模糊怎么办
  11. C4D怎么将模型保存为预设?如何自定义预置库,如何修改别人的预置库?
  12. unity如何实现图片透视_实战 | 自己实现扫描全能王
  13. FB15K-237知识图谱数据集的介绍与分析,Freebase
  14. python网络数据采集 第二版_Python网络数据采集 (影印版)第2版
  15. 使用Sinc卷积从原始音频数据进行轻量级的端到端语音识别
  16. Spring Boot中的配置文件使用以及重新加载
  17. 8.3列表/菜单/文本域标记
  18. 再聊面试,这次关于钱,关于培训,关于内卷
  19. 解决页面js接受Long型损失精度问题
  20. 小梅哥FPGA视频教程学习总结(持续学习中……)

热门文章

  1. ThinkPHP出现 缓存文件写入失败!
  2. Python中相似度对比-difflib模块
  3. 1000以内完数、100以内质数 java
  4. LOL英雄联盟的蛮王,剑圣,赵信相互PK分析
  5. SVN客户端安装配置和使用(windows)
  6. Nat. Methods | 基于机器学习和生物物理的蛋白质-肽相互作用预测
  7. 智能无纸化办公,方便快捷,DIY也很简单
  8. 朴素贝叶斯分类算法python实现
  9. 淘宝自动回复机器人配置手册——售前模板配置(上)
  10. XBOX360更新游戏封皮(FSD自制系统)