Objective-C控件

这篇博客介绍了Objective-C中UILabel的高级用法,包括设置字体行距、混合颜色和字号、添加中划线等。通过NSMutableAttributedString实现这些属性,并提供了Demo链接供读者参考。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这里介绍了Objective-C中一些控件的常用功能,随时补充~
demo地址:Demo 地址


UILabel

有时候我们会有这样的需求:设置label字体的行距、设置同一label里不同颜色/不同字号大小类型的字体、设置中划线/下划线……

NSMutableAttributedString可以设置以上label的常用的属性。 我们先说一下和 attributes有关的四个方法:

 为某一范围内文字设置多个属性
 - (void)setAttributes:(NSDictionary*)attrs range:(NSRange)range;

 为某一范围内文字添加某个属性
 - (void)addAttribute:(NSString*)name value:(id)value range:(NSRange)range;

 为某一范围内文字添加多个属性
 - (void)addAttributes:(NSDictionary*)attrs range:(NSRange)range;

 移除某一范围内的某个属性
 - (void)removeAttribute:(NSString*)name range:(NSRange)range;

通过属性名设置对应的需求value即可实现:

行距:NSParagraphStyleAttributeName
下划线:NSUnderlineStyleAttributeName
下划线颜色:NSUnderlineColorAttributeName
中划线:NSStrikethroughStyleAttributeName
中划线颜色:NSStrikethroughColorAttributeName
字体设置:NSFontAttributeName

demo里我已经封装到了类目里,有需要的可以拖走。

/** 设置不同颜色的字体
 *  @param label : label
 *  @param color : 设置成的特殊颜色
 *  @param colorText  设置特殊颜色的字体
 */
- (void)changeColorWithColor:(UIColor *)color
                   colorText:(NSString *)colorText;

/** 设置不同大小字体的字体
 *  @param font  目标文字的字体设置
 *  @param fontText 目标文字
 */
- (void)changeFontWithFont:(UIFont *)font
                  fontText:(NSString *)fontText;


/** 设置中划线
 *  @param text  要设置中划线的字体
 */
- (void)setThroughLineWithText:(NSString *)text;

/** 设置中划线——自定义颜色
 *  @param text 要设置中划线的字体
 *  @param textColor    要设置中划线的颜色
 */
- (void)setThroughLineWithText:(NSString *)text color:(UIColor *)textColor;



/** 设置下划线
 *  @param text  要设置下划线的字体
 */
- (void)setUnderLineWithText:(NSString *)text;

/** 设置下划线——自定义颜色
 *  @param text 要设置下划线的字体
 *  @param textColor    要设置下划线的颜色
 */
- (void)setUnderLineWithText:(NSString *)text color:(UIColor *)textColor;


/** 设置多行label的行距
 */
- (void)changeLabelSpaceWithSpace:(NSInteger)space text:(NSString *)text;

效果:
这里写图片描述


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值