UILabel實現(xiàn)文字居上,居下,居中

應(yīng)用場景,使用輕量級UILabel實現(xiàn)文字居上顯示,或者居下顯示的特殊UI要求下,使用頻率不高(使用UITextview和UITextFiled也可以做,但是個人感覺不太合適)

代碼如下:
LQLable.h

#import <UIKit/UIKit.h>

typedef NS_ENUM(NSUInteger, LQTextAlignment) {
    LQTextAlignmentTop,
    LQTextAlignmentMiddle,
    LQTextAlignmentBottom,
};

@interface LQLabel : UILabel

@property (nonatomic, assign) LQTextAlignment textAlignment;
@end

LQLable.m

#import "LQLabel.h"

@interface LQLabel ()

@end

@implementation LQLabel

@synthesize textAlignment = textAlignment_;

- (id)initWithFrame:(CGRect)frame {
    if (self = [super initWithFrame:frame]) {
        self.textAlignment = LQTextAlignmentMiddle;
    }
    return self;
}

-(void)setTextAlignment:(LQTextAlignment)textAlignment {
    textAlignment_ = textAlignment;
    [self setNeedsDisplay];
}


- (CGRect)textRectForBounds:(CGRect)bounds limitedToNumberOfLines:(NSInteger)numberOfLines {
    CGRect textRect = [super textRectForBounds:bounds limitedToNumberOfLines:numberOfLines];
    switch (self.textAlignment) {
        case LQTextAlignmentTop:
            textRect.origin.y = bounds.origin.y;
            break;
        case LQTextAlignmentBottom:
            textRect.origin.y = bounds.origin.y + bounds.size.height - textRect.size.height;
            break;
        case LQTextAlignmentMiddle:
            
        default:
            textRect.origin.y = bounds.origin.y + (bounds.size.height - textRect.size.height) / 2.0;
    }
    return textRect;
}

-(void)drawTextInRect:(CGRect)requestedRect {
    CGRect actualRect = [self textRectForBounds:requestedRect limitedToNumberOfLines:self.numberOfLines];
    [super drawTextInRect:actualRect];
}


@end

備注:如有不足請告知??

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市溢豆,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖苍蔬,帶你破解...
    沈念sama閱讀 217,406評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件游两,死亡現(xiàn)場離奇詭異骗卜,居然都是意外死亡,警方通過查閱死者的電腦和手機葵孤,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評論 3 393
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來橱赠,“玉大人佛呻,你說我怎么就攤上這事〔∠撸” “怎么了吓著?”我有些...
    開封第一講書人閱讀 163,711評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長送挑。 經(jīng)常有香客問我绑莺,道長,這世上最難降的妖魔是什么惕耕? 我笑而不...
    開封第一講書人閱讀 58,380評論 1 293
  • 正文 為了忘掉前任纺裁,我火速辦了婚禮,結(jié)果婚禮上司澎,老公的妹妹穿的比我還像新娘欺缘。我一直安慰自己,他們只是感情好挤安,可當(dāng)我...
    茶點故事閱讀 67,432評論 6 392
  • 文/花漫 我一把揭開白布谚殊。 她就那樣靜靜地躺著,像睡著了一般蛤铜。 火紅的嫁衣襯著肌膚如雪嫩絮。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,301評論 1 301
  • 那天围肥,我揣著相機與錄音剿干,去河邊找鬼。 笑死穆刻,一個胖子當(dāng)著我的面吹牛置尔,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播氢伟,決...
    沈念sama閱讀 40,145評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼榜轿,長吁一口氣:“原來是場噩夢啊……” “哼幽歼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起差导,我...
    開封第一講書人閱讀 39,008評論 0 276
  • 序言:老撾萬榮一對情侶失蹤试躏,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后设褐,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體颠蕴,經(jīng)...
    沈念sama閱讀 45,443評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,649評論 3 334
  • 正文 我和宋清朗相戀三年助析,在試婚紗的時候發(fā)現(xiàn)自己被綠了犀被。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,795評論 1 347
  • 序言:一個原本活蹦亂跳的男人離奇死亡外冀,死狀恐怖寡键,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情雪隧,我是刑警寧澤西轩,帶...
    沈念sama閱讀 35,501評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站脑沿,受9級特大地震影響藕畔,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜庄拇,卻給世界環(huán)境...
    茶點故事閱讀 41,119評論 3 328
  • 文/蒙蒙 一注服、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧措近,春花似錦溶弟、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,731評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至凰浮,卻和暖如春我抠,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背袜茧。 一陣腳步聲響...
    開封第一講書人閱讀 32,865評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留瓣窄,地道東北人笛厦。 一個月前我還...
    沈念sama閱讀 47,899評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像俺夕,于是被迫代替她去往敵國和親裳凸。 傳聞我的和親對象是個殘疾皇子贱鄙,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,724評論 2 354

推薦閱讀更多精彩內(nèi)容

  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫、插件姨谷、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 12,102評論 4 62
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,107評論 25 707
  • 英語篇 30本必讀英語書 國學(xué)篇 四書五經(jīng) 歷史篇 講談社?中國歷史 工具篇 Project Office 健身篇...
    礬碼頭閱讀 227評論 0 0
  • 最近整個工作狀態(tài)…“忽冷忽熱”…晚上開完會梦湘,躺床上胡思亂想好多好多瞎颗,最后還是堅定要求自己“老臉厚皮”的學(xué)習(xí),“跳腳...
    我想我會紅閱讀 324評論 0 3
  • 蹉跎歲月捌议,張學(xué)良傳哼拔,芙蓉鎮(zhèn),第三帝國的興亡瓣颅,白鹿原倦逐,平凡的世界,塵埃落定宫补,檀香刑檬姥,
    盤馬老爹閱讀 138評論 1 1