iOS開發筆記 | 自定義具有內邊距的label
前言
UIScrollView
有contentInset
這個屬性,但是UILabel
沒有;Android有,iOS沒有。
最近需要用到帶內邊距的label,所以就結合網上前輩的程式碼封裝了一個,本來我是想弄一個category的,但最終失敗了。
程式碼如下,繼承自UILabel
:
.h檔案:
#import <UIKit/UIKit.h>
@interface EdgeInsetsLabel : UILabel
@property (nonatomic) UIEdgeInsets contentInset;
@end
.m檔案:
#import "EdgeInsetsLabel.h"
@implementation EdgeInsetsLabel
- (void)setContentInset:(UIEdgeInsets)contentInset {
_contentInset = contentInset;
NSString *tempString = self.text;
self.text = @"";
self.text = tempString;
}
-(void)drawTextInRect:(CGRect)rect {
[super drawTextInRect:UIEdgeInsetsInsetRect(rect, self.contentInset)];
}
@end
使用
self.label.contentInset = UIEdgeInsetsMake(0, 20, 0, 20);
程式碼說明
改變label的inset是在這個方法裡面進行的:
-(void)drawTextInRect:(CGRect)rect {
[super drawTextInRect:UIEdgeInsetsInsetRect(rect, self.contentInset)];
}
這是系統提供的方法:
這個方法不能主動呼叫,但我們又需要在這個方法中做處理,怎麼辦?
我實驗了一下,改變label的text的時候會回撥這個方法。
也就是說,我們可以通過改變label的text的方式來間接呼叫這個方法。
所以就有了這段奇葩的賦值contentInset的程式碼:
- (void)setContentInset:(UIEdgeInsets)contentInset {
_contentInset = contentInset;
NSString *tempString = self.text;
self.text = @"";
self.text = tempString;
}
先將label文字清空,再重新賦值text,從而達到改變label的text的效果,最終回撥drawTextInRect:
方法。
這樣我們給label賦值contentInset的時候就能立即看到效果了。
效果GIF:
對應的程式碼:
- (void)viewDidLoad {
[super viewDidLoad];
// Do any additional setup after loading the view, typically from a nib.
self.label = [[EdgeInsetsLabel alloc] initWithFrame:CGRectMake(90, 90, 200, 100)];
[self.view addSubview:self.label];
self.label.text = @"人之初,性本善,我最喜歡吃雞蛋。人之初,性本善,我最喜歡吃雞蛋。人之初,性本善,我最喜歡吃雞蛋。人之初,性本善,我最喜歡吃雞蛋。";
self.label.numberOfLines = 0;
self.label.backgroundColor = [UIColor orangeColor];
self.label.contentInset = UIEdgeInsetsMake(0, 20, 0, 20);
// 3秒後改變contentInset
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(3 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
self.label.contentInset = UIEdgeInsetsMake(20, 50, 10, 20);
});
}
- (void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event {
self.label.contentInset = UIEdgeInsetsMake(0, 80, 0, 20);
self.label.text = @"因缺思廳";
}
demo
最後
如果你有更好的方法不要吝惜分享啊。
2017年12月28日更新
根據評論區neghao同學的建議,要呼叫drawTextInRect
這個方法可以通過呼叫UILabel
的setNeedsDisplay
方法來實現。
所以賦值contentInset就可以改成這樣了:
- (void)setContentInset:(UIEdgeInsets)contentInset {
_contentInset = contentInset;
[self setNeedsDisplay];
}
程式碼已更新到GitHub。
感謝大家的建議。
相關文章
- 自定義UILabel內容顯示內邊距UI
- ios開發筆記--狀態列的自定義,隱藏iOS筆記
- iOS UILabel中文字與邊框間距的自定義iOSUI
- body 預設具有margin外邊距
- iOS學習筆記--PresentedVC自定義彈窗iOS筆記
- iOS開發 AVFoundation自定義相機iOS
- Label--自定義可貼上複製的Label
- iOS 自定義內容的彈窗iOS
- CSS 右內邊距失效CSS
- css中內邊距是padding,外邊距是marginCSSpadding
- iOS開發之有間距的UITableViewCelliOSUIView
- IOS 開發筆記2iOS筆記
- CSS padding內邊距CSSpadding
- CSS padding 內邊距CSSpadding
- Android開發筆記(一百二十四)自定義相簿Android筆記
- Android開發筆記(一百一十八)自定義懸浮窗Android筆記
- 2.15 自定義表單文字框內容的格式 [iOS開發中的神兵利器]iOS
- iOS開發 AVFoundation 自定義視訊錄製iOS
- CSS中父物件的內邊距是否對子物件的外邊距造成影響CSS物件
- body在預設情況下是具有margin外邊距的
- iOS開發自定義View佈局子控制元件iOSView控制元件
- iOS專案開發實戰——配置自定義動畫iOS動畫
- STREAMS筆記(8) rule - 自定義筆記
- iOS自定義的PickViewiOSView
- iOS tableView 分割線左右邊距調整iOSView
- iOS開發備忘筆記 (3)iOS筆記
- iOS開發備忘筆記 (2)iOS筆記
- iOS 邊學邊記iOS
- FineUIMvc隨筆(4)自定義回發引數與自定義回發UIMVC
- 自定義Excel表格邊框的技巧Excel
- iOS開發筆記(一):記憶體管理iOS筆記記憶體
- antd表單的<a-form-item>使用自定義label插槽ORM
- 企業開發app具有重要意義APP
- 筆記3:自定義註解的實現筆記
- iOS開發使用UIKeyInput自定義密碼輸入框iOSUI密碼
- iOS自定義tabBariOStabBar
- 直播平臺開發,自定義中間向兩邊滑動的滑動條
- 表格的邊距 邊框設定