iOS開(kāi)發(fā)實(shí)戰(zhàn)之Label全方位對(duì)齊的輕松實(shí)現(xiàn)
前言
本文主要給大家介紹了關(guān)于iOS Label全方位對(duì)齊的實(shí)現(xiàn)方法,分享出來(lái)供大家參考學(xué)習(xí),下面話不多說(shuō)了,來(lái)一起看看詳細(xì)的介紹吧
ARUILabelTextAlign
1. 實(shí)現(xiàn) UILabel文本在 左(上 中 下)、中(上 中 下)、右(上 中 下) 9個(gè)方位顯示;
2. 提供富文本底部不對(duì)齊的解決方案;
演示
核心代碼:
ARAlignLabel.h
#import <UIKit/UIKit.h> @class ARMaker; typedef NS_ENUM(NSUInteger, textAlignType) { textAlignType_top = 10, // 頂部對(duì)齊 textAlignType_left, // 左邊對(duì)齊 textAlignType_bottom, // 底部對(duì)齊 textAlignType_right, // 右邊對(duì)齊 textAlignType_center // 水平/垂直對(duì)齊(默認(rèn)中心對(duì)齊) }; @interface ARAlignLabel : UILabel /** * 根據(jù)對(duì)齊方式進(jìn)行文本對(duì)齊 * * @param alignType 對(duì)齊block */ - (void)textAlign:(void(^)(ARMaker *make))alignType; @end //工具類 @interface ARMaker : NSObject /* 存放對(duì)齊樣式 */ @property(nonatomic, strong) NSMutableArray *typeArray; /** * 添加對(duì)齊樣式 */ - (ARMaker *(^)(textAlignType type))addAlignType; @end
ARAlignLabel.m
#import "ARAlignLabel.h" @interface ARAlignLabel () /* 對(duì)齊方式 */ @property(nonatomic, strong) NSArray *typeArray; //上 @property(nonatomic, assign) BOOL hasTop; //左 @property(nonatomic, assign) BOOL hasLeft; //下 @property(nonatomic, assign) BOOL hasBottom; //右 @property(nonatomic, assign) BOOL hasRight; @end @implementation ARAlignLabel - (CGRect)textRectForBounds:(CGRect)bounds limitedToNumberOfLines:(NSInteger)numberOfLines { CGRect textRect = [super textRectForBounds:bounds limitedToNumberOfLines:numberOfLines]; if (self.typeArray){ for (int i=0; i<self.typeArray.count; i++) { textAlignType type = [self.typeArray[i] integerValue]; switch (type) { case textAlignType_top: //頂部對(duì)齊 self.hasTop = YES; textRect.origin.y = bounds.origin.y; break; case textAlignType_left: //左部對(duì)齊 self.hasLeft = YES; textRect.origin.x = bounds.origin.x; break; case textAlignType_bottom: //底部對(duì)齊 self.hasBottom = YES; textRect.origin.y = bounds.size.height - textRect.size.height; break; case textAlignType_right: //右部對(duì)齊 self.hasRight = YES; textRect.origin.x = bounds.size.width - textRect.size.width; break; case textAlignType_center: if (self.hasTop) { //上中 textRect.origin.x = (bounds.size.width - textRect.size.width)*0.5; } else if (self.hasLeft) { //左中 textRect.origin.y = (bounds.size.height - textRect.size.height)*0.5; } else if (self.hasBottom) { //下中 textRect.origin.x = (bounds.size.width - textRect.size.width)*0.5; } else if (self.hasRight) { //右中 textRect.origin.y = (bounds.size.height - textRect.size.height)*0.5; } else{ //上下左右居中 textRect.origin.x = (bounds.size.width - textRect.size.width)*0.5; textRect.origin.y = (bounds.size.height - textRect.size.height)*0.5; } break; default: break; } } } return textRect; } - (void)drawTextInRect:(CGRect)requestedRect { CGRect actualRect = requestedRect; if (self.typeArray) { actualRect = [self textRectForBounds:requestedRect limitedToNumberOfLines:self.numberOfLines]; } [super drawTextInRect:actualRect]; } - (void)textAlign:(void(^)(ARMaker *make))alignType { ARMaker *make = [[ARMaker alloc]init]; alignType(make); self.typeArray = make.typeArray; } @end //工具類 @implementation ARMaker - (instancetype)init { self = [super init]; if (self) { self.typeArray = [NSMutableArray array]; } return self; } - (ARMaker *(^)(enum textAlignType type))addAlignType { __weak typeof (self) weakSelf = self; return ^(enum textAlignType type) { [weakSelf.typeArray addObject:@(type)]; return weakSelf; }; } @end
工具使用 - 九個(gè)方位對(duì)齊
- (void)viewDidLoad { [super viewDidLoad]; self.view.backgroundColor = [UIColor whiteColor]; if (_index == 9) { //富文本底部對(duì)齊 [self attributedTextAgainOfBottom]; }else { ARAlignLabel *label = [[ARAlignLabel alloc] initWithFrame:CGRectMake(kScreenWidth/2.0 - 150, 300, 300, 80)]; label.backgroundColor = [UIColor orangeColor]; label.textColor = [UIColor blackColor]; label.font = [UIFont systemFontOfSize:18]; label.text = @"愛(ài)學(xué)習(xí),愛(ài)編程,愛(ài)咖啡可樂(lè)"; label.numberOfLines = 1; [self.view addSubview:label]; switch (_index) { case 0: [label textAlign:^(ARMaker *make) { make.addAlignType(textAlignType_left).addAlignType(textAlignType_top); }]; break; case 1: [label textAlign:^(ARMaker *make) { make.addAlignType(textAlignType_left).addAlignType(textAlignType_center); }]; break; case 2: [label textAlign:^(ARMaker *make) { make.addAlignType(textAlignType_left).addAlignType(textAlignType_bottom); }]; break; case 3: [label textAlign:^(ARMaker *make) { make.addAlignType(textAlignType_center).addAlignType(textAlignType_top); }]; break; case 4: [label textAlign:^(ARMaker *make) { make.addAlignType(textAlignType_center); }]; break; case 5: [label textAlign:^(ARMaker *make) { make.addAlignType(textAlignType_center).addAlignType(textAlignType_bottom); }]; break; case 6: [label textAlign:^(ARMaker *make) { make.addAlignType(textAlignType_right).addAlignType(textAlignType_top); }]; break; case 7: [label textAlign:^(ARMaker *make) { make.addAlignType(textAlignType_right).addAlignType(textAlignType_center); }]; break; case 8: [label textAlign:^(ARMaker *make) { make.addAlignType(textAlignType_right).addAlignType(textAlignType_bottom); }]; break; default: break; } } }
富文本底部對(duì)齊
//富文本底部對(duì)齊 - (void)attributedTextAgainOfBottom { CGFloat space = 10.0; ARAlignLabel *leftLB = [[ARAlignLabel alloc] initWithFrame:CGRectMake(20, 200, kScreenWidth/2.0 - 20 - space/2.0, 80)]; leftLB.backgroundColor = [UIColor lightGrayColor]; leftLB.textColor = [UIColor blackColor]; leftLB.numberOfLines = 1; [self.view addSubview:leftLB]; //右下 [leftLB textAlign:^(ARMaker *make) { make.addAlignType(textAlignType_center); }]; NSMutableAttributedString *attributedArr = [[NSMutableAttributedString alloc] initWithString:@"單價(jià) $123"]; [attributedArr setAttributes:@{NSFontAttributeName:[UIFont systemFontOfSize:40], NSForegroundColorAttributeName:[UIColor blackColor]} range:NSMakeRange(0, 1)]; [attributedArr setAttributes:@{NSFontAttributeName:[UIFont systemFontOfSize:25], NSForegroundColorAttributeName:[UIColor blackColor]} range:NSMakeRange(1, 1)]; [attributedArr setAttributes:@{NSFontAttributeName:[UIFont systemFontOfSize:20], NSForegroundColorAttributeName:[UIColor blueColor]} range:NSMakeRange(3, 1)]; [attributedArr setAttributes:@{NSFontAttributeName:[UIFont systemFontOfSize:35], NSForegroundColorAttributeName:[UIColor redColor]} range:NSMakeRange(4, attributedArr.length - 4)]; leftLB.attributedText = attributedArr; //對(duì)齊之后 ARAlignLabel *rightLB = [[ARAlignLabel alloc] initWithFrame:CGRectMake(kScreenWidth/2.0 + space/2.0, 200, leftLB.frame.size.width, 80)]; rightLB.backgroundColor = [UIColor lightGrayColor]; rightLB.textColor = [UIColor blackColor]; rightLB.numberOfLines = 1; [self.view addSubview:rightLB]; //左下 [rightLB textAlign:^(ARMaker *make) { make.addAlignType(textAlignType_center); }]; //設(shè)置部分文字的偏移量 (0是讓文字保持原來(lái)的位置, 負(fù)值是讓文字下移,正值是讓文字上移) [attributedArr addAttribute:NSBaselineOffsetAttributeName value:@(1) range:NSMakeRange(0, 1)]; [attributedArr addAttribute:NSBaselineOffsetAttributeName value:@(0) range:NSMakeRange(1, 1)]; [attributedArr addAttribute:NSBaselineOffsetAttributeName value:@(-2) range:NSMakeRange(3, 1)]; [attributedArr addAttribute:NSBaselineOffsetAttributeName value:@(-3) range:NSMakeRange(4, attributedArr.length - 4)]; rightLB.attributedText = attributedArr; }
富文本底部對(duì)齊 - 使用場(chǎng)景:
Github:https://github.com/ArchLL/ARUILabelTextAlign (本地下載)
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
iOS緩存文件大小顯示功能和一鍵清理功能的實(shí)現(xiàn)方法
緩存占用了系統(tǒng)的大量空間,如何實(shí)時(shí)動(dòng)態(tài)的顯示緩存的大小,使用戶清晰的了解緩存的積累情況,有效的進(jìn)行一鍵清理呢?下面小編通過(guò)本文給大家介紹iOS緩存文件大小顯示功能和一鍵清理功能的實(shí)現(xiàn)方法,一起看看吧2016-10-10關(guān)于iOS自帶九宮格拼音鍵盤(pán)和Emoji表情之間的一些坑
這篇文章主要給大家介紹了關(guān)于iOS自帶九宮格拼音鍵盤(pán)和Emoji表情之間的一些坑文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)各位iOS開(kāi)發(fā)者們具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2018-05-05IOS 實(shí)現(xiàn)微信自動(dòng)搶紅包(非越獄IPhone)
這篇文章主要介紹了IOS 實(shí)現(xiàn)微信自動(dòng)搶紅包(非越獄IPhone)的相關(guān)資料,這里對(duì)實(shí)現(xiàn)自動(dòng)搶紅包做一個(gè)詳細(xì)的實(shí)現(xiàn)步驟,需要的朋友可以參考下2016-11-11iOS給border設(shè)置漸變色的方法實(shí)例
這篇文章主要給大家介紹了關(guān)于iOS給border設(shè)置漸變色的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03實(shí)例解析iOS app開(kāi)發(fā)中音頻文件播放工具類的封裝
這篇文章主要介紹了iOS app開(kāi)發(fā)中音頻文件播放工具類的封裝,代碼基于傳統(tǒng)的Objective-C,需要的朋友可以參考下2016-01-01iOS系統(tǒng)緩存方面開(kāi)發(fā)的相關(guān)基礎(chǔ)
這篇文章主要介紹了iOS系統(tǒng)緩存方面開(kāi)發(fā)的相關(guān)基礎(chǔ),示例代碼基于傳統(tǒng)的Objective-C,需要的朋友可以參考下2015-10-10