服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - IOS - iOS利用NSAttributedString实现图文混排效果示例

iOS利用NSAttributedString实现图文混排效果示例

2021-04-02 18:09Mazy_ma IOS

iOS7以后,因为TextKit的强大,可以用NSAttributedString很方便的实现图文混排(主要是利用了NSTextAttachment),所以下面这篇文章主要给大家介绍了关于iOS利用NSAttributedString实现图文混排效果的相关资料,需要的朋友可以参考借鉴,下面

前言

nsattributedstring 可以非常方便的实现文字排版和图文混排功能,uilabel 和 uitextview 都能添加 nsattributedstring 属性字符串,通过这一点,可以实现带有属性的文字和文字内包含图片的文本内容展示。话不多说了,下面来一起看看详细的介绍吧。

效果如下:

iOS利用NSAttributedString实现图文混排效果示例

iOS利用NSAttributedString实现图文混排效果示例

示例代码如下:

1-初始化可变属性字符串

?
1
nsmutableattributedstring *attributedstring = [[nsmutableattributedstring alloc]initwithstring:textstring];

2-设置全局字体属性(设置字体大小为14)

?
1
2
[attributedstring addattribute:nsfontattributename value:[uifont systemfontofsize:14] range:nsmakerange(0, textstring.length)];
[attributedstring addattribute:nskernattributename value:@1 range:nsmakerange(0, textstring.length)];

上面两句代码可以简写为一句(为属性字符串同时添加多个属性)

?
1
[attributedstring addattributes:@{nsfontattributename: [uifont systemfontofsize:14],nskernattributename: @1} range:nsmakerange(0, textstring.length)];

3-修改标题文字属性

通过字符串获取范围

?
1
[attributedstring addattributes:@{nsfontattributename: [uifont systemfontofsize:26],nsforegroundcolorattributename: [uicolor bluecolor]} range:[textstring rangeofstring:@"360云盘服务转型公告"]];

4-获取一大段文字范围并修改属性

通过前后字符串获取大段字符的范围

?
1
2
3
4
// 此方法可以通过string获得范围进行修改
nsrange startrange = [textstring localizedstandardrangeofstring:@"我们即将采取以下措施:"];
nsrange endrange = [textstring localizedstandardrangeofstring:@"感谢您的一路相伴。"];
[attributedstring addattribute:nsforegroundcolorattributename value:[uicolor redcolor] range:nsunionrange(startrange, endrange)];

5-为文本添加下划线

?
1
2
3
4
// 设置文本下划线
nsrange startrange1 = [textstring localizedstandardrangeofstring:@"因此,"];
nsrange endrange1 = [textstring localizedstandardrangeofstring:@"之后转型企业云服务。"];
[attributedstring addattribute:nsunderlinestyleattributename value:@1 range:nsunionrange(startrange1, endrange1)];

6-为文本内文字添加描边

?
1
2
3
4
// 设置文本的描边
[attributedstring addattribute:nsstrokewidthattributename value:@2.0 range:[textstring rangeofstring:@"存储传播非法文件、侵权盗版牟利、传播淫秽色情信息等违法犯罪行为"]];
[attributedstring addattribute:nsstrokecolorattributename value:[uicolor browncolor] range:[textstring rangeofstring:@"存储传播非法文件、侵权盗版牟利、传播淫秽色情信息等违法犯罪行为"]];
[attributedstring addattribute:nsfontattributename value:[uifont systemfontofsize:17] range:[textstring rangeofstring:@"存储传播非法文件、侵权盗版牟利、传播淫秽色情信息等违法犯罪行为"]];

7-为文本添加图片附件

?
1
2
3
4
5
6
// 插入图片附件
nstextattachment *imageatta = [[nstextattachment alloc] init];
imageatta.bounds = cgrectmake(0, 0, 375, 180);
imageatta.image = [uiimage imagenamed:@"360"];
nsattributedstring *attach = [nsattributedstring attributedstringwithattachment:imageatta];
[attributedstring insertattributedstring:attach atindex:0];

8-为文本设置段落属性

?
1
2
3
4
5
6
7
8
9
// 段落样式
nsmutableparagraphstyle *style = [[nsmutableparagraphstyle alloc]init];
// 行间距
[style setlinespacing:3];
// 段落间距
[style setparagraphspacing:6];
// 首行缩进
[style setfirstlineheadindent:25];
[attributedstring addattribute:nsparagraphstyleattributename value:style range:nsmakerange(1, textstring.length)];

9-添加网址链接

?
1
2
3
4
// 网址链接
nsrange urlrange = [textstring rangeofstring:@"yunpan.360.cn"];
[attributedstring addattribute:nslinkattributename value:[nsurl urlwithstring:@"http://yunpan.360.cn"] range:nsmakerange(urlrange.location, 14)];
[attributedstring addattribute:nsbackgroundcolorattributename value:[uicolor greencolor] range:nsmakerange(urlrange.location, 14)];

10-通过uitextviewdelegate代理方法,监听url和附件的点击

?
1
2
3
4
5
6
7
8
9
10
#pragma mark ----------uitextviewdelegate----------
- (bool)textview:(uitextview *)textview shouldinteractwithurl:(nsurl *)url inrange:(nsrange)characterrange interaction:(uitextiteminteraction)interaction {
 nslog(@"%@",url);
 return yes;
}
 
- (bool)textview:(uitextview *)textview shouldinteractwithtextattachment:(nstextattachment *)textattachment inrange:(nsrange)characterrange interaction:(uitextiteminteraction)interaction {
 nslog(@"%@",textattachment.image);
 return yes;
}

补充:常用属性字符串属性

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
// 字体
nsfontattributename    // uifont, default helvetica(neue) 12
// 段落
nsparagraphstyleattributename  // nsparagraphstyle, default defaultparagraphstyle
// 文字颜色
nsforegroundcolorattributename // uicolor, default blackcolor
// 背景颜色
nsbackgroundcolorattributename // uicolor, default nil: no background
// 描边颜色
nsstrokecolorattributename  // uicolor, default nil: same as foreground color
// 描边宽度
nsstrokewidthattributename  // nsnumber containing floating point value, default 0
// 阴影
nsshadowattributename    // nsshadow, default nil: no shadow
// 附件
nsattachmentattributename   // nstextattachment, default nil
// 链接url
nslinkattributename    // nsurl (preferred) or nsstring
// 基线偏移量
nsbaselineoffsetattributename  // nsnumber containing floating point value,default 0
// 下划线
nsunderlinecolorattributename  // uicolor, default nil: same as foreground color

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对服务器之家的支持。

原文链接:http://blog.csdn.net/mazy_ma/article/details/52920596

延伸 · 阅读

精彩推荐
  • IOSiOS通过逆向理解Block的内存模型

    iOS通过逆向理解Block的内存模型

    自从对 iOS 的逆向初窥门径后,我也经常通过它来分析一些比较大的应用,参考一下这些应用中某些功能的实现。这个探索的过程乐趣多多,不仅能满足自...

    Swiftyper12832021-03-03
  • IOSIOS 屏幕适配方案实现缩放window的示例代码

    IOS 屏幕适配方案实现缩放window的示例代码

    这篇文章主要介绍了IOS 屏幕适配方案实现缩放window的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要...

    xiari5772021-06-01
  • IOS解析iOS开发中的FirstResponder第一响应对象

    解析iOS开发中的FirstResponder第一响应对象

    这篇文章主要介绍了解析iOS开发中的FirstResponder第一响应对象,包括View的FirstResponder的释放问题,需要的朋友可以参考下...

    一片枫叶4662020-12-25
  • IOSIOS开发之字典转字符串的实例详解

    IOS开发之字典转字符串的实例详解

    这篇文章主要介绍了IOS开发之字典转字符串的实例详解的相关资料,希望通过本文能帮助到大家,让大家掌握这样的方法,需要的朋友可以参考下...

    苦练内功5832021-04-01
  • IOS关于iOS自适应cell行高的那些事儿

    关于iOS自适应cell行高的那些事儿

    这篇文章主要给大家介绍了关于iOS自适应cell行高的那些事儿,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的...

    daisy6092021-05-17
  • IOSiOS 雷达效果实例详解

    iOS 雷达效果实例详解

    这篇文章主要介绍了iOS 雷达效果实例详解的相关资料,需要的朋友可以参考下...

    SimpleWorld11022021-01-28
  • IOSiOS中tableview 两级cell的展开与收回的示例代码

    iOS中tableview 两级cell的展开与收回的示例代码

    本篇文章主要介绍了iOS中tableview 两级cell的展开与收回的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    J_Kang3862021-04-22
  • IOSiOS布局渲染之UIView方法的调用时机详解

    iOS布局渲染之UIView方法的调用时机详解

    在你刚开始开发 iOS 应用时,最难避免或者是调试的就是和布局相关的问题,下面这篇文章主要给大家介绍了关于iOS布局渲染之UIView方法调用时机的相关资料...

    windtersharp7642021-05-04