简易使用UILabel的富文本

时间:2022-12-17 15:18:49

简易使用UILabel的富文本

简易使用UILabel的富文本

使用效果:

简易使用UILabel的富文本

源码:

NSString+YX.h    NSString+YX.m

//
// NSString+YX.h
// YXKit
//
// Copyright (c) 2014年 Y.X. All rights reserved.
// #import <Foundation/Foundation.h>
#import "ConfigAttributedString.h" @interface NSString (YX) // 创建富文本并配置富文本(NSArray中的数据必须是ConfigAttributedString对象合集)
- (NSMutableAttributedString *)createAttributedStringAndConfig:(NSArray *)configs; // 用于搜寻一段字符串在另外一段字符串中的NSRange值
- (NSRange)rangeFrom:(NSString *)string; // 本字符串的range
- (NSRange)range; @end
//
// NSString+YX.m
// YXKit
//
// Copyright (c) 2014年 Y.X. All rights reserved.
// #import "NSString+YX.h" @implementation NSString (YX) - (NSMutableAttributedString *)createAttributedStringAndConfig:(NSArray *)configs
{
NSMutableAttributedString *attributedString = \
[[NSMutableAttributedString alloc] initWithString:self]; [configs enumerateObjectsUsingBlock:^(id obj, NSUInteger idx, BOOL *stop) {
ConfigAttributedString *oneConfig = obj;
[attributedString addAttribute:oneConfig.attribute
value:oneConfig.value
range:oneConfig.range];
}]; return attributedString;
} - (NSRange)rangeFrom:(NSString *)string
{
return [string rangeOfString:self];
} - (NSRange)range
{
return NSMakeRange(, self.length);
} @end

ConfigAttributedString.h   ConfigAttributedString.m

//
// ConfigAttributedString.h
// NSMutableAttributedString
//
// Copyright (c) 2014年 Y.X. All rights reserved.
// #import <Foundation/Foundation.h> @interface ConfigAttributedString : NSObject @property (nonatomic, strong, readonly) NSString *attribute; // 富文本属性
@property (nonatomic, strong, readonly) id value; // 富文本值
@property (nonatomic, assign, readonly) NSRange range; // 富文本范围值 // 通用型配置
+ (instancetype)attribute:(NSString *)attribute
value:(id)value
range:(NSRange)range; // 配置字体
+ (instancetype)font:(UIFont *)font
range:(NSRange)range; // 配置字体颜色
+ (instancetype)foregroundColor:(UIColor *)color
range:(NSRange)range; // 配置字体背景颜色
+ (instancetype)backgroundColor:(UIColor *)color
range:(NSRange)range; // 字体描边颜色以及描边宽度以及阴影(以下两个方法可以一起使用)
+ (instancetype)strokeColor:(UIColor *)color
range:(NSRange)range;
+ (instancetype)strokeWidth:(float)number
range:(NSRange)range;
+ (instancetype)shadow:(NSShadow *)shadow
range:(NSRange)range; // 配置文字的中划线
+ (instancetype)strikethroughStyle:(NSInteger)number
range:(NSRange)range; // 配置文字的下划线
+ (instancetype)underlineStyle:(NSInteger)number
range:(NSRange)range; // 字间距
+ (instancetype)kern:(float)number
range:(NSRange)range; // 段落样式(需要将UILabel中的numberOfLines设置成0才有用)
+ (instancetype)paragraphStyle:(NSMutableParagraphStyle *)style
range:(NSRange)range; @end
//
// ConfigAttributedString.m
// NSMutableAttributedString
//
// Copyright (c) 2014年 Y.X. All rights reserved.
// #import "ConfigAttributedString.h" @interface ConfigAttributedString () @property (nonatomic, strong) NSString *attribute;
@property (nonatomic, strong) id value;
@property (nonatomic, assign) NSRange range; @end @implementation ConfigAttributedString + (instancetype)attribute:(NSString *)attribute value:(id)value range:(NSRange)range
{
ConfigAttributedString *config = [self new]; config.attribute = attribute;
config.value = value;
config.range = range; return config;
} + (instancetype)font:(UIFont *)font range:(NSRange)range
{
ConfigAttributedString *config = [self new];
config.attribute = NSFontAttributeName;
config.value = font;
config.range = range; return config;
} + (instancetype)foregroundColor:(UIColor *)color range:(NSRange)range
{
ConfigAttributedString *config = [self new];
config.attribute = NSForegroundColorAttributeName;
config.value = color;
config.range = range; return config;
} + (instancetype)backgroundColor:(UIColor *)color range:(NSRange)range
{
ConfigAttributedString *config = [self new];
config.attribute = NSBackgroundColorAttributeName;
config.value = color;
config.range = range; return config;
} + (instancetype)strikethroughStyle:(NSInteger)number range:(NSRange)range
{
ConfigAttributedString *config = [self new];
config.attribute = NSStrikethroughStyleAttributeName;
config.value = [NSNumber numberWithInteger:number];
config.range = range; return config;
} + (instancetype)paragraphStyle:(NSMutableParagraphStyle *)style range:(NSRange)range
{
ConfigAttributedString *config = [self new];
config.attribute = NSParagraphStyleAttributeName;
config.value = style;
config.range = range; return config;
} + (instancetype)kern:(float)number range:(NSRange)range
{
ConfigAttributedString *config = [self new];
config.attribute = NSKernAttributeName;
config.value = [NSNumber numberWithFloat:number];
config.range = range; return config;
} + (instancetype)underlineStyle:(NSInteger)number range:(NSRange)range
{
ConfigAttributedString *config = [self new];
config.attribute = NSUnderlineStyleAttributeName;
config.value = [NSNumber numberWithInteger:number];
config.range = range; return config;
} + (instancetype)strokeColor:(UIColor *)color range:(NSRange)range
{
ConfigAttributedString *config = [self new];
config.attribute = NSStrokeColorAttributeName;
config.value = color;
config.range = range; return config;
} + (instancetype)strokeWidth:(float)number range:(NSRange)range
{
ConfigAttributedString *config = [self new];
config.attribute = NSStrokeWidthAttributeName;
config.value = [NSNumber numberWithFloat:number];
config.range = range; return config;
} + (instancetype)shadow:(NSShadow *)shadow range:(NSRange)range
{
ConfigAttributedString *config = [self new];
config.attribute = NSShadowAttributeName;
config.value = shadow;
config.range = range; return config;
} @end

控制器源码:

//
// RootViewController.m
// RichText
//
// Copyright (c) 2014年 Y.X. All rights reserved.
// #import "RootViewController.h"
#import "NSString+YX.h" @interface RootViewController () @end @implementation RootViewController - (void)viewDidLoad
{
[super viewDidLoad]; // 字符串
NSString *str = @"未选择的路-弗罗斯特\n黄色的树林里分出两条路,\n可惜我不能同时去涉足,\n我在那路口久久伫立,\n我向着一条路极目望去,\n直到它消失在丛林深处。\n但我却选了另外一条路,\n它荒草萋萋,十分幽寂,\n显得更诱人、更美丽,\n虽然在这两条小路上,\n都很少留下旅人的足迹,\n虽然那天清晨落叶满地,\n两条路都未经脚印污染。\n啊,留下一条路等改日再见!\n但我知道路径延绵无尽头,\n恐怕我难以再回返。\n也许多少年后在某个地方,\n我将轻声叹息把往事回顾,\n一片树林里分出两条路,\n而我选了人迹更少的一条,\n从此决定了我一生的道路。"; // 设置组
NSArray *array = \
@[// 全局设置
[ConfigAttributedString font:[UIFont systemFontOfSize:.f] range:[str range]],
[ConfigAttributedString paragraphStyle:[self style] range:[str range]], // 局部设置
[ConfigAttributedString foregroundColor:[UIColor redColor]
range:[@"未选择的路" rangeFrom:str]],
[ConfigAttributedString font:[UIFont systemFontOfSize:.f]
range:[@"未选择的路" rangeFrom:str]]]; // 初始化富文本
UILabel *label = [[UILabel alloc] initWithFrame:self.view.bounds];
label.numberOfLines = ;
label.attributedText = [str createAttributedStringAndConfig:array];
[self.view addSubview:label];
} // 段落样式
- (NSMutableParagraphStyle *)style
{
NSMutableParagraphStyle *style = [NSMutableParagraphStyle new];
style.lineSpacing = .f;
style.firstLineHeadIndent = .f; return style;
} @end

设计原理:

我把配置抽象成了一个对象,一个对象可能对应着不同的配置,这样写起来就不会乱

简易使用UILabel的富文本

使用的时候直接就在数组中配置

简易使用UILabel的富文本

通过NSString的Category直接生成富文本赋值给attributedText即完成了富文本的操作

简易使用UILabel的富文本

这才叫面向对象编程嘛:)

简易使用UILabel的富文本的更多相关文章

  1. UILabel的富文本显示选项

    UILabel的富文本格式设置 1.实例化方法和使用方法 实例化方法: 使用字符串初始化 - (id)initWithString:(NSString *)str; 例: NSMutableAttri ...

  2. UILabel设置富文本后不显示省略号

    先描述一下问题,项目中用到了UILabel去显示一段富文本文字,超过label显示区域部分,省略号处理. 但是当设置好 attributedText 给label之后,显示出的效果是文字被切割了,并没 ...

  3. UILabel设置富文本格式显示

    实例化方法和使用方法 实例化方法: 使用字符串初始化 - (id)initWithString:(NSString *)str; 例: NSMutableAttributedString *Attri ...

  4. UILabel富文本 段落格式以及UILabel添加图片

    之前文本整理有一点乱,这边重新整理一下,下面是效果图,一共两个UILabel, 富文本整理: /*NSForegroundColorAttributeName设置字体颜色,对象UIColor; NSP ...

  5. UILabel添加图片之富文本的简单应用

    若想对UILabel添加图片,那么就需要使用NSMutableAttributedString来定义先定义一个普通的label UILabel *lab = [[UILabel alloc]initW ...

  6. UIlabel - 富文本属性

    1.NSKernAttributeName: @10 调整字句 kerning 字句调整 2.NSFontAttributeName : [UIFont systemFontOfSize:_fontS ...

  7. 简易富文本编辑器bootstrap-wysiwyg源码注释

    好久没写随笔了,因为最近比较忙,小公司基本都是一个前端干所有属于和部分不属于前端的事情,所以就没空弄了,即使想分享,也因为没有时间和精力就搁置了. 这周周六日休息,正好时间比较充裕(ps:目前处在单休 ...

  8. UILabel&lpar;富文本&rpar;

    本文转载至 http://www.jianshu.com/p/5d24d22f99c3 富文本 NSString *str = @"人生若只如初见,何事秋风悲画扇.\n等闲变却故人心,却道故 ...

  9. iOS UIlabel怎么加载html字符串 富文本的用法

    要加载html字符串,用人说,直接用webView啊!但是,有时候我们只需要显示2行文字,如此少的内容却要在复杂的UI排版中加入一个占用资源较多的webview,得不偿失.这里要说的是,我们其实可以用 ...

随机推荐

  1. Unix domain sockets

    #server: SERVER_PATH = "/tmp/python_unix_socket_server" def run_unix_domain_socket_server( ...

  2. Project&colon; Individual Project - Word frequency program----11061192zmx

    Description & Requirements http://www.cnblogs.com/jiel/p/3311400.html 项目时间估计 理解项目要求: 1小时 构建项目逻辑: ...

  3. 深入了解一下PYTHON中关于SOCKETSERVER的模块-D

    在LINUX上以FORK的方式使用SIMPLEHTTPSERVER. 记得哟,THREADING能在WIN和LINUX上实现,但FORK,不支持WIN的. 除了SIMPLE之外,还有CGI,就不示例啦 ...

  4. bug修复复盘

    mybatis与数据库交互时,报了莫名其妙的错,日志中显示的Stack Trace中报错的代码行数与IDE中还一致,逐重启tomcat,异常消失. 故障复盘:没有重启tomcat,使用copy命令直接 ...

  5. 谷歌制图服务&lpar;Google Chart&rpar;接口生成二维码

    Google公布了制图服务(Google Chart)的接口,这项服务用起来相当简单,只使用浏览器就可以用来为统计数据自动生成图片. 目前谷歌制图服务提供折线图.条状图.饼图.Venn图.散点图.二维 ...

  6. pm2进阶使用

    启用集群模式 只需要在启动应用时带上i参数 pm2 start app.js -i max max:意味着PM2将自动检测可用的CPU数量和运行多个进程可以在负载均衡模式(但是不推荐使用) 或者使用j ...

  7. java-HTML&amp&semi;javaSkcript&amp&semi;CSS&amp&semi;jQuery&amp&semi;ajax

    CSS  伪装 1.<style>a;link{color:#000000} a:visited{color:#000000; a.:hover{color:#FF00FF} a:acti ...

  8. Vue:生命周期

    一.什么是vue的生命周期 Vue中的生命周期是指组件从创建到销毁的一系列过程.看下面这张官方文档的图: 从图片中可以看出Vue的整个生命周期包括8个状态,按照先后顺序分别为: beforeCreat ...

  9. qt ISO C&plus;&plus; forbids declaration of &&num;39&semi;XXXX&&num;39&semi; with no type

    error: ISO C++ forbids declaration of 'XXXX' with no type   出现这个错误,一般是由于两个CPP相互都相互包含了对方的头文件造成的,比如: 当 ...

  10. CentOS 安装 Hadoop

    原文地址:http://www.cnblogs.com/caca/p/centos_hadoop_install.html 下载和安装   download hadoop from http://ha ...