IOS總結_實現UIButton的圖文混排,同時顯示文字和圖片

來源:互聯網
上載者:User

IOS總結_實現UIButton的圖文混排,同時顯示文字和圖片

我們常常需要用到按鈕需要文字和圖片同時顯示,例如:

 

我們需要定義一個UIButton的子類

 

實現檔案

 

- (id)initWithFrame:(CGRect)frame

{

self = [super initWithFrame:frame];

if (self) {

//可根據自己的需要隨意調整

self.titleLabel.textAlignment=NSTextAlignmentRight;

self.titleLabel.font=[UIFont systemFontOfSize:14.0];

self.imageView.contentMode=UIViewContentModeLeft;

}

return self;

}

//重寫父類UIButton的方法

 

//更具button的rect設定並返迴文本label的rect

- (CGRect)titleRectForContentRect:(CGRect)contentRect

{

CGFloat titleW = contentRect.size.width-30;

CGFloat titleH = contentRect.size.height;

CGFloat titleX = 0;

CGFloat titleY = 0;

 

contentRect = (CGRect){{titleX,titleY},{titleW,titleH}};

return contentRect;

}

 

//更具button的rect設定並返回UIImageView的rect

- (CGRect)imageRectForContentRect:(CGRect)contentRect

{

CGFloat imageW = 25;

CGFloat imageH = 25;

CGFloat imageX = contentRect.size.width-26;

CGFloat imageY = 2.5;

 

contentRect = (CGRect){{imageX,imageY},{imageW,imageH}};

return contentRect;

}

 

 

//使用UIButton的子類

yxpButton *selectAreaButton=[[yxpButton alloc] initWithFrame:CGRectMake(200, 5, 100, 30)];

[selectAreaButton setTitle:@"圖文混排" forState:UIControlStateNormal];

[selectAreaButton setImage:[UIImage imageNamed:@"location"] forState:UIControlStateNormal];

[selectAreaButton setTitleColor:[UIColor whiteColor] forState:UIControlStateNormal];

[navigationBgView addSubview:selectAreaButton];


就這樣 就可以實現一個按鈕的圖文混排了

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.