iOS-UIButton 全面解析

UIButton 的全面解析

建議收藏,用到的時(shí)候來(lái)這里一查就都明白了
//初始化Button 不用alloca init 的方法 用便利構(gòu)造器初始化
UIButton *button = [UIButton buttonWithType:UIButtonTypeSystem];

typedef NS_ENUM(NSInteger, UIButtonType) {
    UIButtonTypeCustom = 0,       -自定義風(fēng)格
    UIButtonTypeSystem NS_ENUM_AVAILABLE_IOS(7_0),
    UIButtonTypeDetailDisclosure, -藍(lán)色小箭頭按鈕,主要做詳細(xì)說(shuō)明
    UIButtonTypeInfoLight,        -亮色感嘆號(hào)
    UIButtonTypeInfoDark,         -暗色感嘆號(hào)
    UIButtonTypeContactAdd,       -十字加號(hào)按鈕
    UIButtonTypeRoundedRect = UIButtonTypeSystem,  -圓角矩形
};
//設(shè)置button frmae 
button.frame = CGRectMake(100, 100, 100, 100);
//設(shè)置button 背景顏色
button.backgroundColor = [UIColor orangeColor];
//添加button的標(biāo)題
[button setTitle:@"登陸" forState:UIControlStateNormal];
//設(shè)置標(biāo)題的顏色
[button setTitleColor:[UIColor redColor] forState:UIControlStateNormal];
//設(shè)置標(biāo)題字體的大小
button.titleLabel.font = [UIFont systemFontOfSize:20];
//設(shè)置button的背景圖片
[button setBackgroundImage:[UIImage imageNamed:@"11.png"] forState:UIControlStateNormal];
//獲取指定狀態(tài)下的背景圖片
UIImage *tempImage = [button imageForState:UIControlStateNormal];
//設(shè)置前景圖片  前景圖片必須是鏤空?qǐng)D,或者是線條勾勒的圖片
[button setImage:[UIImage imageNamed:@"7.png"] forState:UIControlStateNormal];
//設(shè)置陰影顏色
[button setTitleShadowColor:[UIColor purpleColor] forState:UIControlStateNormal];

//button 一些其他屬性
@property(nonatomic)  UIEdgeInsets contentEdgeInsets; 內(nèi)容內(nèi)距離
@property(nonatomic)  UIEdgeInsets titleEdgeInsets;   標(biāo)題內(nèi)距離
@property(nonatomic)  BOOL  reversesTitleShadowWhenHighlighted; 標(biāo)題的陰影改變時(shí),按鈕是否高亮顯示。默認(rèn)為NO
@property(nonatomic)  UIEdgeInsets imageEdgeInsets;   圖片內(nèi)邊距
@property(nonatomic)  BOOL adjustsImageWhenHighlighted;按鈕高亮的情況下,圖像的顏色是否要加深一點(diǎn)。默認(rèn)是YES
@property(nonatomic)  BOOL adjustsImageWhenDisabled; 按鈕禁用的情況下,圖像的顏色是否要加深一點(diǎn)。默認(rèn)是YES
@property(nonatomic)  BOOL showsTouchWhenHighlighted; 按下按鈕是否會(huì)發(fā)光 默認(rèn)是NO
@property(nonatomic,readonly) UIButtonType buttonType; button的類型



設(shè)置button某個(gè)狀態(tài)的標(biāo)題
- (void)setTitle:(nullable NSString *)title forState:(UIControlState)state;
例: [button setTitle:@"開(kāi)燈" forState:UIControlStateNormal];

設(shè)置button某個(gè)狀態(tài)的標(biāo)題顏色
- (void)setTitleColor:(nullable UIColor *)color forState:(UIControlState)state
例:[button setTitleColor:[UIColor blueColor] forState:UIControlStateNormal];

設(shè)置button某個(gè)狀態(tài)陰影的標(biāo)題顏色
- (void)setTitleShadowColor:(nullable UIColor *)color forState:(UIControlState)state
例:[button setTitleShadowColor:[UIColor purpleColor] forState:UIControlStateNormal];

設(shè)置button某個(gè)狀態(tài)圖片
- (void)setImage:(nullable UIImage *)image forState:(UIControlState)state;

設(shè)置button 某個(gè)狀態(tài)背景圖片
- (void)setBackgroundImage:(nullable UIImage *)image forState:(UIControlState)state UI_APPEARANCE_SELECTOR; // default is nil

設(shè)置button 某個(gè)狀態(tài)下的富文本標(biāo)題
- (void)setAttributedTitle:(nullable NSAttributedString *)title forState:(UIControlState)state NS_AVAILABLE_IOS(6_0); // default is nil. title is assumed to be single line

返回button 某個(gè)狀態(tài)下的標(biāo)題
- (nullable NSString *)titleForState:(UIControlState)state;

返回button 某個(gè)狀態(tài)下的標(biāo)題顏色
- (nullable UIColor *)titleColorForState:(UIControlState)state;

返回button 某個(gè)狀態(tài)下的陰影標(biāo)題顏色
- (nullable UIColor *)titleShadowColorForState:(UIControlState)state;

返回button 某個(gè)狀態(tài)下的圖片
- (nullable UIImage *)imageForState:(UIControlState)state;

返回button 某個(gè)狀態(tài)下的背景圖片
- (nullable UIImage *)backgroundImageForState:(UIControlState)state;

返回button 某個(gè)狀態(tài)下的富文本標(biāo)題
- (nullable NSAttributedString *)attributedTitleForState:(UIControlState)state NS_AVAILABLE_IOS(6_0);

/* forState: 這個(gè)參數(shù)的作用是定義按鈕的文字或圖片在何種狀態(tài)下才會(huì)顯現(xiàn)*/
以下是幾種狀態(tài)
 enum {
UIControlStateNormal = 0, 常規(guī)狀態(tài)顯現(xiàn)
UIControlStateHighlighted = 1 << 0, 高亮狀態(tài)顯現(xiàn)
UIControlStateDisabled = 1 << 1, 禁用的狀態(tài)才會(huì)顯現(xiàn)
UIControlStateSelected = 1 << 2, 選中狀態(tài)
UIControlStateApplication = 0x00FF0000, 當(dāng)應(yīng)用程序標(biāo)志時(shí)
UIControlStateReserved = 0xFF000000 為內(nèi)部框架預(yù)留,可以不管他
 };



獲取按鈕當(dāng)前標(biāo)題
@property(nullable, nonatomic,readonly,strong) NSString *currentTitle;

獲取按鈕當(dāng)前標(biāo)題顏色
@property(nonatomic,readonly,strong) UIColor  *currentTitleColor;

獲取按鈕當(dāng)前陰影標(biāo)題顏色
@property(nullable, nonatomic,readonly,strong) UIColor *currentTitleShadowColor;

獲取按鈕當(dāng)前按鈕內(nèi)圖像
@property(nullable, nonatomic,readonly,strong) UIImage  *currentImage;

獲取按鈕當(dāng)前標(biāo)題背景圖片
@property(nullable, nonatomic,readonly,strong) UIImage  *currentBackgroundImage;

獲取按鈕當(dāng)前標(biāo)題富文本
@property(nullable, nonatomic,readonly,strong) NSAttributedString *currentAttributedTitle

@property(nullable, nonatomic,readonly,strong) UILabel    *titleLabel NS_AVAILABLE_IOS(3_0);
@property(nullable, nonatomic,readonly,strong) UIImageView *imageView  NS_AVAILABLE_IOS(3_0);

指定背景邊界
- (CGRect)backgroundRectForBounds:(CGRect)bounds;
指定內(nèi)容邊界
- (CGRect)contentRectForBounds:(CGRect)bounds;
指定標(biāo)題邊界
- (CGRect)titleRectForContentRect:(CGRect)contentRect;
指定圖片邊界
- (CGRect)imageRectForContentRect:(CGRect)contentRect;

示例:
- (CGRect)imageRectForContentRect:(CGRect)bounds{
        return CGRectMake(0.0, 0.0, 44, 44);
    }
@end

//給按鈕添加點(diǎn)擊事件
[button addTarget:self action:@selector(action:) forControlEvents:UIControlEventTouchUpInside];

枚舉值:
    UIControlEventTouchDown             // 單點(diǎn)觸摸按下事件:用戶點(diǎn)觸屏幕,或者又有新手指落下的時(shí)候。
    UIControlEventTouchDownRepeat       // 多點(diǎn)觸摸按下事件,點(diǎn)觸計(jì)數(shù)大于1:用戶按下第二、三、或第四根手指的時(shí)候。
    UIControlEventTouchDragInside       // 當(dāng)一次觸摸在控件窗口內(nèi)拖動(dòng)時(shí)。
    UIControlEventTouchDragOutside      // 當(dāng)一次觸摸在控件窗口之外拖動(dòng)時(shí)。
    UIControlEventTouchDragEnter        // 當(dāng)一次觸摸從控件窗口之外拖動(dòng)到內(nèi)部時(shí)
    UIControlEventTouchDragExit         // 當(dāng)一次觸摸從控件窗口內(nèi)部拖動(dòng)到外部時(shí)。
    UIControlEventTouchUpInside         // 所有在控件之內(nèi)觸摸抬起事件
    UIControlEventTouchUpOutside        // 所有在控件之外觸摸抬起事件(點(diǎn)觸必須開(kāi)始與控件內(nèi)部才會(huì)發(fā)送通知)。
    UIControlEventTouchCancel           // 所有觸摸取消事件,即一次觸摸因?yàn)榉派狭颂嗍种付蝗∠蛘弑簧湘i或者電話呼叫打斷。

    UIControlEventValueChanged          // 當(dāng)控件的值發(fā)生改變時(shí),發(fā)送通知。用于滑塊、分段控件、以及其他取值的控件。你可以配置滑塊控件何時(shí)發(fā)送通知,在滑塊被放下時(shí)發(fā)送,或者在被拖動(dòng)時(shí)發(fā)送。

    UIControlEventEditingDidBegin       // 當(dāng)文本控件中開(kāi)始編輯時(shí)發(fā)送通知
    UIControlEventEditingChanged        // 當(dāng)文本控件中的文本被改變時(shí)發(fā)送通知。
    UIControlEventEditingDidEnd         // 當(dāng)文本控件中編輯結(jié)束時(shí)發(fā)送通知。
    UIControlEventEditingDidEndOnExit   // 當(dāng)文本控件內(nèi)通過(guò)按下回車鍵(或等價(jià)行為)結(jié)束編輯時(shí),發(fā)送通知。

    UIControlEventAllTouchEvents        // 通知所有觸摸事件。
    UIControlEventAllEditingEvents      // 通知所有關(guān)于文本編輯的事件。
    UIControlEventApplicationReserved   // range available for application use
    UIControlEventSystemReserved        // range reserved for internal framework use

    UIControlEventAllEvents             // 通知所有事件

如果有錯(cuò)誤的地方請(qǐng)大家多多指正,歡迎評(píng)論交流,共同學(xué)習(xí)。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,835評(píng)論 6 534
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,676評(píng)論 3 419
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人,你說(shuō)我怎么就攤上這事。” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 176,730評(píng)論 0 380
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 63,118評(píng)論 1 314
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 71,873評(píng)論 6 410
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 55,266評(píng)論 1 324
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,330評(píng)論 3 443
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 42,482評(píng)論 0 289
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,036評(píng)論 1 335
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 40,846評(píng)論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,025評(píng)論 1 371
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,575評(píng)論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,279評(píng)論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 34,684評(píng)論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 35,953評(píng)論 1 289
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 51,751評(píng)論 3 394
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,016評(píng)論 2 375

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