ios富文本的简单使用 AttributedString

富文本,顾名思义就是丰富的文本格式,本文demo使用NSMutableAttributedString

//获取富文本
    NSMutableAttributedString*attributeString_atts=[[NSMutableAttributedString alloc]initWithString:string];
    //背景色
    UIColor  *backgroundColor=[UIColor whiteColor];
    //字体
    UIFont *font=[UIFont fontWithName:@"STHeitiSC-Light" size:18.0];
    //偏移量
    NSNumber *baseLineOffset=[NSNumber numberWithFloat:10.0];
    //文本颜色
    UIColor  *foregroundColor=[UIColor blackColor];
    //字间距
    NSNumber *kern=[NSNumber numberWithFloat:1.5];
    //连体字
    NSNumber *ligature=[NSNumber numberWithFloat:0];
    //超链接文本
    NSURL    *linkURL=[NSURL URLWithString:@"www.baidu.com"];
    //下划线格式
    NSNumber *underLine=[NSNumber numberWithInt:NSUnderlineStyleSingle];
    //段落格式 段落中有更多段落的格式
    NSMutableParagraphStyle *paragraphStyle=[[NSMutableParagraphStyle alloc]init];
    //行间距
    [paragraphStyle setLineSpacing:10.0];
    //新起行缩进
//    [paragraphStyle setHeadIndent:10.0];
    //首行缩进
    [paragraphStyle setFirstLineHeadIndent:21.0];
    //断行 默认按单词
//    paragraphStyle.lineBreakMode=NSLineBreakByWordWrapping;
    //
//    [paragraphStyle setTailIndent:375.0];
    NSDictionary *[email protected]{
                             NSForegroundColorAttributeName:foregroundColor,
                             NSBackgroundColorAttributeName:backgroundColor,
//                            NSBaselineOffsetAttributeName:baseLineOffset,
                                        NSFontAttributeName:font,
                                        NSKernAttributeName:kern,
                                    NSLigatureAttributeName:ligature,
//                                      NSLinkAttributeName:linkURL,
//                            NSUnderlineStyleAttributeName:underLine,
                              NSParagraphStyleAttributeName:paragraphStyle
                             };

  //全文使用
    [attributeString_atts addAttributes:attrsDic range:NSMakeRange(0, [string length])];

  //计算富文本的宽度
    CGRect attrsRect=[attributeString_atts boundingRectWithSize:CGSizeMake(self.view.frame.size.width-20, CGFLOAT_MAX)  options:NSStringDrawingUsesLineFragmentOrigin|NSStringDrawingUsesFontLeading context:nil];
    NSLog(@"%f",attrsRect.size.width);
    NSLog(@"%f",attrsRect.size.height);
    UILabel*label=[[UILabel alloc]initWithFrame:CGRectMake(10, 200*number, self.view.frame.size.width-20, attrsRect.size.height)];
    label.attributedText=attributeString_atts;
    label.userInteractionEnabled=YES;
    label.numberOfLines=0;
    [self.view addSubview:label];

AttributedString的创建方式,下面研究下AttributedString究竟可以设置哪些属性,具体来说,有以下21个:
 
// NSFontAttributeName                        设置字体属性,默认值:字体:Helvetica(Neue) 字号:12
// NSForegroundColorAttributeNam          设置字体颜色,取值为 UIColor对象,默认值为黑色
// NSBackgroundColorAttributeName     设置字体所在区域背景颜色,取值为 UIColor对象,默认值为nil, 透明色
// NSLigatureAttributeName                设置连体属性,取值为NSNumber 对象(整数),0 表示没有连体字符,1 表示使用默认的连体字符
// NSKernAttributeName                    设定字符间距,取值为 NSNumber 对象(整数),正值间距加宽,负值间距变窄
// NSStrikethroughStyleAttributeName  设置删除线,取值为 NSNumber 对象(整数)
// NSStrikethroughColorAttributeName  设置删除线颜色,取值为 UIColor 对象,默认值为黑色
// NSUnderlineStyleAttributeName          设置下划线,取值为 NSNumber 对象(整数),枚举常量 NSUnderlineStyle中的值,与删除线类似
// NSUnderlineColorAttributeName      设置下划线颜色,取值为 UIColor 对象,默认值为黑色
// NSStrokeWidthAttributeName             设置笔画宽度,取值为 NSNumber 对象(整数),负值填充效果,正值中空效果
// NSStrokeColorAttributeName             填充部分颜色,不是字体颜色,取值为 UIColor 对象
// NSShadowAttributeName                  设置阴影属性,取值为 NSShadow 对象
// NSTextEffectAttributeName              设置文本特殊效果,取值为 NSString 对象,目前只有图版印刷效果可用:
// NSBaselineOffsetAttributeName      设置基线偏移值,取值为 NSNumber (float),正值上偏,负值下偏
// NSObliquenessAttributeName         设置字形倾斜度,取值为 NSNumber (float),正值右倾,负值左倾
// NSExpansionAttributeName               设置文本横向拉伸属性,取值为 NSNumber (float),正值横向拉伸文本,负值横向压缩文本
// NSWritingDirectionAttributeName        设置文字书写方向,从左向右书写或者从右向左书写
// NSVerticalGlyphFormAttributeName   设置文字排版方向,取值为 NSNumber 对象(整数),0 表示横排文本,1 表示竖排文本
// NSLinkAttributeName                      设置链接属性,点击后调用打开指定URL地址
// NSAttachmentAttributeName          设置文本附件,取值为NSTextAttachment对象,常用于文字图片混排
// NSParagraphStyleAttributeName      设置文本段落排版格式,取值为 NSParagraphStyle 对象

paragraph
  alignment             //对齐方式
  firstLineHeadIndent     //首行缩进
  headIndent             //缩进
  tailIndent              //尾部缩进
  lineBreakMode          //断行方式
  maximumLineHeight      //最大行高
  minimumLineHeight      //最低行高
  lineSpacing              //行距
  paragraphSpacing         //段距
  paragraphSpacingBefore  //段首空间
  baseWritingDirection      //句子方向
  lineHeightMultiple      //可变行高,乘因数。
  hyphenationFactor     //连字符属性

时间: 2024-10-09 02:49:52

ios富文本的简单使用 AttributedString的相关文章

iOS富文本组件的实现—DTCoreText源码解析 数据篇

本文转载 http://blog.cnbang.net/tech/2630/ DTCoreText是个开源的iOS富文本组件,它可以解析HTML与CSS最终用CoreText绘制出来,通常用于在一些需要显示富文本的场景下代替低性能的UIWebView,来看看它是怎样解析和渲染HTML+CSS的,总体上分成两步: 数据解析—把HTML+CSS转换成NSAttributeString 渲染—用CoreText把NSAttributeString内容渲染出来,再加上图片等元素 本篇先介绍第一步,数据解

iOS 富文本

富文本 http://pan.baidu.com/s/1pJnY8BL 把这里下载的文件夹拖进自己的工程 引入头文件 #import "OHAttributedLabel.h" #import "OHParagraphStyle.h" #import "OHTouchesGestureRecognizer.h" 引入这3个头文件 添加 CoreText.framework // 创建富文本string NSMutableAttributedStr

iOS富文本-NSAttributedString简单封装

直接调用系统的写起来比较麻烦,封装一下 因为要简单所以就写类方法 WJAttributeStyle 基类 #import <Foundation/Foundation.h>#import <UIKit/UIKit.h>/** *  基类富文本 */@interface WJAttributeStyle : NSObject @property (nonatomic,strong)NSString *attributeName;@property (nonatomic,strong)

ios富文本

之前做项目时遇到一个问题: 使用UITextView显示一段电影的简介,由于字数比较多,所以字体设置的很小,行间距和段间距也很小,一大段文字挤在一起看起来很别扭,想要把行间距调大,结果在XCode中查遍其所有属性才发现,UITextView居然没有调整行间距的接口,于是忍住不心里抱怨了一下下. 但是问题还是要解决的,上网一查才发现,iOS不仅有富文本处理的功能,而且对于文字排版的处理能力那是相当的强大,看来我是孤陋寡闻了. 正题开始之前插播一点基础知识: 在iOS中或者Mac OS X中怎样才能

IOS 富文本 ,设置行间距、字间距,计算高度(转载组合而成)

一 计算高度 -(CGFloat)getSpaceLabelHeight:(NSString*)str withFont:(UIFont*)font withWidth:(CGFloat)width { NSMutableParagraphStyle *paraStyle = [[NSMutableParagraphStyle alloc] init]; paraStyle.lineBreakMode = NSLineBreakByCharWrapping; paraStyle.alignmen

iOS 富文本格式字符 以及处理iOS8下textview设置富文本后输入bug

iOS的富文本设置,在iOS8下在textView的代理方法中设置textview的attributedText时,会出现富文本格式未加到text上的情况,可以在初始化时将文本属性赋给textview的typingAttributes.代码如下: NSMutableParagraphStyle *paragraphStyle = [[NSMutableParagraphStyle alloc] init]; paragraphStyle.lineSpacing = 7;// 字体的行间距 UIF

iOS 富文本初探

有的时候啊,我们需要在一行或者多行文本中显示不同颜色,不同字号的文字,甚至于有的需要点击,有的不需要.这统称为富文本. 在网页中,有很多类似的应用.除开网页,我现在遇到的这种情况也是非用不可,用户政策和用户协议在多语言的实现中,考虑到自适应,就必须显示在同一个控件中(UILabel/UITextView). NSMutableAttributedString/NSAttributedString用来表示富文本. 不如我们有一段文本,中间有两段是要求不同颜色显示,可以点击的,因为是国际化,每一段的

iOS 富文本类库RTLabel

本文转载至 http://blog.csdn.net/duxinfeng2010/article/details/9004749 本节关于RTLable基本介绍,原文来自 https://github.com/honcheng/RTLabel RTLabel 基于富文本的格式,适用于iOS,类似HTML的标记. RTLabel 基于UILabel类的拓展,能够支持Html标记的富文本显示,它是基于Core Text,因此也支持Core Text上的一些东西. 特点 粗体和斜体 颜色和大小 下划线

富文本内容简单的的增删改查

由于html本身的textarea标签的文本编辑功能较为简单,不能设置文字的样式,因此需要富文本控件来增强textarea的功能.       一些常见的富文本控件有:UEditor.kindeditor.simditor.bootstrap-wysiwyg.wangEditor.CKEditor.tinymce,各有优缺点,网上也有对不介绍,不再赘述. 此处选用tinymce,因其兼容性较好,插入页面也较为简单,此外还有丰富的插件可以扩展功能. 首先,在页面上使用tinymce:1.引入js文