UILabel富文本 段落格式以及UILabel添加图片
之前文本整理有一点乱,这边重新整理一下,下面是效果图,一共两个UILabel,

富文本整理:
/*NSForegroundColorAttributeName设置字体颜色,对象UIColor;
NSParagraphStyleAttributeName设置段落格式,对象NSMutableParagraphStyle;
NSFontAttributeName设置字体,对象UIFont;
NSBackgroundColorAttributeName设置背景颜色,对象UIColor;
NSKernAttributeName设置字符间距,对象NSNumber
NSStrikethroughStyleAttributeName是指删除线样式 对象NSUnderlineStyle
NSStrikethroughColorAttributeName删除线颜色,对象UIColor
NSUnderlineStyleAttributeName设置下划线,参考删除线
NSUnderlineColorAttributeName设置下划线颜色
NSStrokeWidthAttributeName设置笔画宽度,对象NSNumber,负值填充效果,正值中空效果
NSStrokeColorAttributeName当文字中空或者填充设置文字的描边颜色,对象UIColor;
NSShadowAttributeName 设置阴影,NSShadow对象
NSBaselineOffsetAttributeName设置基线偏移值,对象NSNumber (float),正值上偏,负值下偏
NSObliquenessAttributeName设置字形倾斜度,对象NSNumber (float),正值右倾,负值左倾
NSExpansionAttributeName 设置文本横向拉伸属性,对象NSNumber (float),正值横向拉伸文本,负值横向压缩文本
NSVerticalGlyphFormAttributeName 设置文字排版方向,取值为 NSNumber 对象(整数),0 表示横排文本,1 表示竖排文本
NSLinkAttributeName设置链接属性,点击后调用浏览器打开指定URL地址,对象NSString,NSUrl,这个只能UITextView可用UITextView的代理方法中shouldInteractWithURL返回true可用
NSTextEffectAttributeName设置文本特殊效果,目前只有一个可用效果 NSTextEffectLetterpressStyle(凸版印刷效果
设置连体属性,取值为NSNumber 对象(整数),0 表示没有连体字符,1 表示使用默认的连体字符//没有测出效果
*/
源码展示:
NSString *text = @"池塘大桥下,游过一群鸭,快来快来数一数,二四六七八,嘎嘎嘎嘎,真呀真多呀,fly,数不清到底多少鸭";
NSMutableParagraphStyle * paragraphStyle = [[NSMutableParagraphStyle alloc] init];
//行间距为
[paragraphStyle setLineSpacing:8];
NSMutableAttributedString *string = [[NSMutableAttributedString alloc] initWithString:text attributes:@{NSForegroundColorAttributeName : [UIColor blueColor], NSParagraphStyleAttributeName: paragraphStyle, NSFontAttributeName:[UIFont boldSystemFontOfSize:18]}] ; //设置特殊字体文本格式
NSRange range = [text rangeOfString:@"池塘大桥下"];
[string addAttributes:@{NSForegroundColorAttributeName:[UIColor redColor],
NSFontAttributeName:[UIFont boldSystemFontOfSize:12],NSBackgroundColorAttributeName:[UIColor yellowColor],NSKernAttributeName:@(12),NSStrikethroughStyleAttributeName:@(NSUnderlineStyleDouble),NSStrikethroughColorAttributeName:[UIColor purpleColor]} range:range];//添加属性 NSRange range1 = [text rangeOfString:@"游过"];
[string addAttributes:@{NSStrokeWidthAttributeName:@(-2),NSStrokeColorAttributeName:[UIColor redColor]} range:range1];//添加属性 NSRange range2 = [text rangeOfString:@"一群鸭"];
NSShadow *shadow = [NSShadow new];
[shadow setShadowColor:[UIColor redColor]];
[shadow setShadowOffset:CGSizeMake(5.0f, 5.0f)];//设置x,y轴偏移量
[shadow setShadowBlurRadius:1.0];//设置模糊度
[string addAttributes:@{NSShadowAttributeName:shadow} range:range2];//添加属性 NSRange range3 = [text rangeOfString:@"快来快来"];
[string addAttributes:@{NSBaselineOffsetAttributeName:@(10)} range:range3];//添加属性 NSRange range4 = [text rangeOfString:@"数一数"];
[string addAttributes:@{NSObliquenessAttributeName:@(0.5)} range:range4];//添加属性
NSRange range5 = [text rangeOfString:@"二四"];
[string addAttributes:@{NSExpansionAttributeName:@(0.8)} range:range5];//添加属性
NSRange range6 = [text rangeOfString:@"六七八"];
[string addAttributes:@{NSExpansionAttributeName:@(-0.8)} range:range6];//添加属性 /**
没有测出具体的区别
NSWritingDirectionAttributeName 设置文字书写方向,从左向右书写或者从右向左书写
@[@(NSWritingDirectionLeftToRight | NSWritingDirectionEmbedding)]
@[@(NSWritingDirectionLeftToRight | NSWritingDirectionOverride)]
@[@(NSWritingDirectionRightToLeft | NSWritingDirectionEmbedding)]
@[@(NSWritingDirectionRightToLeft | NSWritingDirectionOverride)]
*/ [string addAttributes:@{NSWritingDirectionAttributeName:@[@(NSWritingDirectionRightToLeft | NSWritingDirectionEmbedding)]} range:NSMakeRange(0, text.length)];//添加属性 [string addAttributes:@{NSVerticalGlyphFormAttributeName:@1} range:NSMakeRange(0, text.length)];//添加属性 NSRange range8 = [text rangeOfString:@"嘎嘎嘎嘎"];
NSURL *url = [NSURL URLWithString:@"http://www.baidu.com"];
[string addAttributes:@{NSLinkAttributeName:url} range:range8];//添加属性
NSRange range9 = [text rangeOfString:@"真呀真多呀"];
[string addAttributes:@{NSTextEffectAttributeName:NSTextEffectLetterpressStyle} range:range9];//添加属性
NSRange range10 = [text rangeOfString:@"fly"];
[string addAttributes:@{NSLigatureAttributeName:@0} range:range10];//添加属性 self.label.attributedText = string;
NSMutableParagraphStyle用法整理:
NSTextAttachment *attachment = [[NSTextAttachment alloc] init];
//使用一张图片作为Attachment数据
attachment.image = [UIImage imageNamed:@"chepaihao"];
//这里bounds的x值并不会产生影响
attachment.bounds = CGRectMake(5, (self.label1.font.lineHeight - self.label1.font.pointSize) / 2, 20, 10);
NSMutableParagraphStyle * paragraphStyle1 = [[NSMutableParagraphStyle alloc] init];
[paragraphStyle1 setLineSpacing:20];
//首行缩进
[paragraphStyle1 setFirstLineHeadIndent:20];
[paragraphStyle1 setLineBreakMode:NSLineBreakByTruncatingMiddle];
//两端对齐的)文本对齐方式
paragraphStyle1.minimumLineHeight = 10;//最低行高
paragraphStyle1.maximumLineHeight = 20;//最大行高
paragraphStyle1.paragraphSpacing = 45;//段与段之间的间距
// paragraphStyle1.paragraphSpacingBefore = 1000;//段首行空白空间
paragraphStyle1.baseWritingDirection = NSWritingDirectionLeftToRight;//从左到右的书写方向(一共➡️三种)
// paragraphStyle1.lineHeightMultiple = -100;没有测出效果
// paragraphStyle1.hyphenationFactor = 1;//连字属性 在iOS,唯一支持的值分别为0和1
NSMutableAttributedString *attributedString = [[NSMutableAttributedString alloc] initWithString:@"你是一个好人,你是一个好人,你是一个好人,你是一个好人,你是一个好人,你是一个好人,你是一个好人,你是一个好人,你是一个好人,你是一个好人" attributes:@{NSParagraphStyleAttributeName: paragraphStyle1}];
[attributedString appendAttributedString:[NSAttributedString attributedStringWithAttachment:attachment]];
[attributedString appendAttributedString:[NSAttributedString attributedStringWithAttachment:attachment]];
[attributedString appendAttributedString:[[NSMutableAttributedString alloc] initWithString:@"\n你是一个好人,你是一个好人,你是一个好人,你是一个好人,你是一个好人,你是一个好人,你是一个好人,你是一个好人,你是一个好人,你是一个好人" attributes:@{NSParagraphStyleAttributeName: paragraphStyle1}]];
[attributedString appendAttributedString:[NSAttributedString attributedStringWithAttachment:attachment]];
self.label1.backgroundColor = [UIColor redColor];
// self.label1.textAlignment = NSTextAlignmentCenter;
self.label1.attributedText = attributedString;
// self.label1.lineBreakMode = NSLineBreakByCharWrapping;
获取富文本的高度和普通label的高度一样:
CGSize attSize = [string boundingRectWithSize:CGSizeMake(width, MAXFLOAT) options:NSStringDrawingUsesLineFragmentOrigin | NSStringDrawingUsesFontLeading context:nil].size;
注意事项:我们设置NSMutableParagraphStyle的lineSpacing可能和我们想象的不大一样,间距会比我们想象的高一点点,如果我们设置10个像素,就需要这么设置,减去系统自带的间距
paragraphStyle.lineSpacing = 10 - (label.font.lineHeight - label.font.pointSize);
UILabel富文本 段落格式以及UILabel添加图片的更多相关文章
- Swift中的富文本注释格式
Apple当前启用了Markup语法形式的富文本注释格式,并且为此列出了官方文档,可以参考此链接:https://developer.apple.com/library/ios/documentati ...
- UIlabel - 富文本属性
1.NSKernAttributeName: @10 调整字句 kerning 字句调整 2.NSFontAttributeName : [UIFont systemFontOfSize:_fontS ...
- UILabel(富文本)
本文转载至 http://www.jianshu.com/p/5d24d22f99c3 富文本 NSString *str = @"人生若只如初见,何事秋风悲画扇.\n等闲变却故人心,却道故 ...
- JAVAEE——宜立方商城04:图片服务器FastDFS、富文本编辑器KindEditor、商品添加功能完成
1. 学习计划 1.图片上传 a) 图片服务器FastDFS b) 图片上传功能实现 2.富文本编辑器的使用KindEditor 3.商品添加功能完成 2. 图片服务器的安装 1.存储空间可扩展. 2 ...
- Java 读取Word文本/段落格式属性
本文介绍通过Java后端程序代码来读取Word文本和段落格式的方法. 本次测试环境如下: Word版本:2013 编译环境:IntelliJ IDEA2018 Work库:free spire.doc ...
- vue富文本编辑器vue-quill-editor使用总结(包含图片上传,拖拽,放大和缩小)
vue-quill-editor是vue很好的富文本编辑器,富文本的功能基本上都支持,样式是黑白色,简洁大方. 第一步下载 vue-quill-editor: npm i vue-quill-edit ...
- 富文本编辑器CKeditor的配置和图片上传,看完不后悔
CKeditor是一款富文本编辑器,本文将用极为简单的方式介绍一下它的使用和困扰大家很久的图片上传问题,要有耐心. 第一步:如何使用 1.官网下载https://ckeditor.com/ckedit ...
- vue v-html 富文本解析 空格,换行,图片大小问题
1.保留空格,换行属性 //保留换行空格问题 white-space: pre-wrap; 2.超出部分,强制换行,一般用于数字 //富文本换行 word-wrap: break-word; tabl ...
- C# WinForm 富文本编辑器 用kindeditor实现本地图片只选取不上传到编辑器
以下资料有参考网上其它童鞋作品,原作者看到务喷!!!! 以下资料有参考网上其它童鞋作品,原作者看到务喷!!!! 重要的事只要说两遍... 网上找了几天关于WinForm富文本编辑效果都不理想,各种坑, ...
随机推荐
- C++ template —— 深入模板基础(二)
上一篇C++ template —— 模板基础(一)讲解了有关C++模板的大多数概念,日常C++程序设计中所遇到的很多问题,都可以从这部分教程得到解答.本篇中我们深入语言特性.------------ ...
- 《转载》Fiddler 抓包工具总结
阅读目录 1. Fiddler 抓包简介 1). 字段说明 2). Statistics 请求的性能数据分析 3). Inspectors 查看数据内容 4). AutoResponder 允许拦截制 ...
- js 简易模板引擎 , 持续更新。。。
<script> var _mytpl = (function(){ var _verson = 1.0; return { _data:{}, load:function(html,da ...
- icon VS html特殊字符
好久没来了,最近项目很多,今天要说的是个页面上用到的icon. 话“icon” 现在有很多icon库,我们再也不用切图来适配不同的分辨率了,但是对于新手来说,查阅icon库来找到适合的icon,实在费 ...
- sencha touch 监听视图切换动画(animation)
var animation = this.getLayout().getAnimation(); //添加监听 animation.on({ scope: this, animationend: 'o ...
- shell 进制转换
包括: i.任意进制转化为十进制((num=base#number)) [base和number必须一致,是同一种进制] ii.十进制转化为任意进制`echo "obase=进制;值&quo ...
- Android Usb Camera HAL框架
- 关于egret.Tween传递参数的问题
参考: setTimeOut传参数(转) setTimeout传参数 CSDN 一.延迟后执行,并输出参数 for(let i=0;i<10;i++){ egret.Tween.get(this ...
- [图书] C++
作者 书名 Bjarne Stroustrup The Design and Evolution of C++Stanley B. Lippman C++ PrimerStanley B. ...
- iOS - 原生的CIFilter生成二维码和条形码
使用CIFilter可以不引入任何第三方库,就可以生成想要的二维码和条形码,今天简单的介绍一下使用CIFilter生成二维码和条形码.系统CIFilter生成的二维码和条形码的大小有时并不能满足需求, ...