UIButton按鈕

UIButton *button = [UIButton buttonWithType:UIButtonTypeSystem];
//buttonWithType后面填的是button的樣式
//UIButtonTypeSystem的時候如果給button添加前景圖片只能顯示出一個藍(lán)色的輪廓;
//建議只要給UIButton設(shè)置自定義圖片,就用Custom
//想要添加前景圖片需要改成UIButtonTypeCustom;
button.frame = CGRectMake(100,100,100,100);
//設(shè)置標(biāo)題
[button setTitle:@"登陸" forState:UIControlStateNormal];
  • 這里的State填的是當(dāng)button這個狀態(tài)的時候顯示這樣的標(biāo)題;
    • Normal狀態(tài)就是沒有按的時候的狀態(tài)
    • HighLighted狀態(tài)就是按住不放的時候的狀態(tài)
    • disable狀態(tài)就是按鈕失效或者不能按的時候的狀態(tài)
    • 可以給不同的狀態(tài)設(shè)定不同的圖片,標(biāo)題等
//取標(biāo)題
NSString *title = [button titleForState:UIControlStateNormal];
//設(shè)置標(biāo)題字體的顏色
[button setTitleColor:[UIColor redColor] forState:UIControlStateNormal];
//背景圖片
[button setBackgroundImage:[UIImage imageNamed:@"XXX.jpg"] forState:UIControlStateNormal];
//設(shè)置背景圖片時上面的Type設(shè)為System就行了;

//設(shè)置前景圖片
[button setImage:[UIImage imageNamed:@"XXX.jpg"] forState:UIControlStateNormal];
//設(shè)置前景圖片時上面的Type要用Custem

//取圖片
UIImage *backImg = [button backgroundImageForState:UIControlStateNormal];
UIImage *img = [button imageForState:UIControlStateNormal];
[self.window addSubview:button];
//button不用release,因為一般都是用便利構(gòu)造器構(gòu)建

//點(diǎn)擊事件
[button addTarget:self action:@selector(buttonAction:) forControlEvents:UIControlEventTouchUpInside];
//forControlEvents后填的是點(diǎn)擊事件觸發(fā)的時機(jī);是一點(diǎn)下就觸發(fā),還是點(diǎn)下松手之后在觸發(fā)

自定義button

想要自定義Button中的圖片和標(biāo)題的位置有兩種方法
1.寫一個UIButton的子類,并實現(xiàn)兩個方法

//此方法改變的是標(biāo)題的位置大小,返回標(biāo)題的frame,
//此處contentRect就是button的frame,下同
- (CGRect)titleRectForContentRect:(CGRect)contentRect
//此方法改變的是圖片的位置大小,返回圖片的frame
- (CGRect)imageRectForContentRect:(CGRect)contentRect

2.設(shè)置UIButton相應(yīng)的EdgeInsets屬性

button.titleEdgeInsets = UIEdgeInsetsMake(top,left,bottom,right);
button.imageEdgeInsets = UIEdgeInsetsMake(top,left,bottom,right);
//這兩個屬性設(shè)置的是圖片和標(biāo)題距離邊框的距離,當(dāng)只有圖片或標(biāo)題時,
//設(shè)置的是距離button邊框的距離,
//同時存在時,設(shè)置的圖片的上左下是距button邊框的距離,右邊是距離title的距離;
//title上下右是距button邊框的距離,左邊是距離image的距離
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容