iOS 調(diào)整UIBarButtonItem的間距

根據(jù)iOS系統(tǒng)方法創(chuàng)建的UIBarButtonItem間距在一般看來是比較大的, 如果想要調(diào)整, 可以嘗試以下一種方法:
首先創(chuàng)建兩個(gè)UIBarButtonItem

UIBarButtonItem *item1 = [[UIBarButtonItem alloc] initWithImage:[UIImage imageNamed:@"gouwuche.png"]     style:UIBarButtonItemStylePlain target:nil action:nil];
UIBarButtonItem *item2 = [[UIBarButtonItem alloc] initWithImage:[UIImage imageNamed:@"search.png"] style:UIBarButtonItemStylePlain target:nil action:nil];
self.navigationItem.rightBarButtonItems = @[item1,item2];

運(yùn)行結(jié)果如下:

Paste_Image.png
  1. 使用UIBarButtonSystemItemFixedSpace
    網(wǎng)上有的說創(chuàng)建一個(gè)type為UIBarButtonSystemItemFixedSpace的UIBarButtonItem進(jìn)行占位, 并將其設(shè)置為負(fù)值,以期實(shí)現(xiàn)減小間距的效果.
    親測代碼如下:
UIBarButtonItem *item1 = [[UIBarButtonItem alloc] initWithImage:[UIImage imageNamed:@"gouwuche.png"] style:UIBarButtonItemStylePlain target:nil action:nil];
UIBarButtonItem *item2 = [[UIBarButtonItem alloc] initWithImage:[UIImage imageNamed:@"search.png"] style:UIBarButtonItemStylePlain target:nil action:nil];
//新加的代碼
UIBarButtonItem *space = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemFixedSpace target:nil action:nil];
space.width = -10;
self.navigationItem.rightBarButtonItems = @[space,item1,item2];

可以看到購物車距離右邊框的距離縮小了.


Paste_Image.png

但是當(dāng)我視圖再在item1 和 item2 之間加一個(gè)space2 時(shí), 如果當(dāng)width值為正數(shù)時(shí), 間距會(huì)增加, 當(dāng)width的值為負(fù)值, 間距并沒有變小. 所以總結(jié), 此法只有在調(diào)整UIBarButtonItem 到左右邊距時(shí)有效.
2.自定義Button
由于使用系統(tǒng)默認(rèn)的方法創(chuàng)建的UIBarButtonItem 的大小并不是由我們決定的, 所以我們可以通過自己創(chuàng)建一個(gè)自定義大小的button的方式來創(chuàng)建一個(gè)UIBarButtonItem, 以達(dá)到縮小間隔的目的.代碼如下:

    UIButton *btn1 = [UIButton buttonWithType:UIButtonTypeCustom];
    [btn1 setImage:[UIImage imageNamed:@"gouwuche.png"]    forState:UIControlStateNormal];
    [btn1 setFrame:CGRectMake(0, 0, 30, 30)];
    UIBarButtonItem *item1 = [[UIBarButtonItem alloc]initWithCustomView:btn1];
    UIButton *btn2 = [UIButton buttonWithType:UIButtonTypeCustom];
    [btn2 setImage:[UIImage imageNamed:@"search.png"] forState:UIControlStateNormal];
    [btn2 setFrame:CGRectMake(0, 0, 30, 30)];
    UIBarButtonItem *item2 = [[UIBarButtonItem alloc]initWithCustomView:btn2];
    self.navigationItem.rightBarButtonItems = @[item1,item2];
可以看到間距確實(shí)減小了:

Paste_Image.png

3.設(shè)置UIEdgeInsets
如果是通過圖片創(chuàng)建的UIBarButtonItem, 我們可以通過設(shè)置imageInsets屬性來調(diào)整image到按鈕的距離, 來縮小間距:
UIBarButtonItem *item1 = [[UIBarButtonItem alloc] initWithImage:[UIImage imageNamed: @"gouwuche.png"]
style:UIBarButtonItemStylePlain
target:nil
action:nil];
UIBarButtonItem *item2 = [[UIBarButtonItem alloc] initWithImage:[UIImage imageNamed:@"search.png"]
style:UIBarButtonItemStylePlain target:nil action:nil];
//設(shè)置圖片與按鈕間距
[item2 setImageInsets:UIEdgeInsetsMake(0, 15, 0, -15)];
self.navigationItem.rightBarButtonItems = @[item1,item2];

Paste_Image.png

總結(jié): 如果是用圖片創(chuàng)建的UIBarButtonItem , 第三種方式較為簡單; 如果是通過圖片以外的方式創(chuàng)建可以通過第二種方式實(shí)現(xiàn); 如果只是想調(diào)整按鈕到兩邊的距離, 用第一種方式即可.

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末尤泽,一起剝皮案震驚了整個(gè)濱河市欣簇,隨后出現(xiàn)的幾起案子规脸,更是在濱河造成了極大的恐慌,老刑警劉巖熊咽,帶你破解...
    沈念sama閱讀 207,113評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件莫鸭,死亡現(xiàn)場離奇詭異,居然都是意外死亡横殴,警方通過查閱死者的電腦和手機(jī)被因,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,644評(píng)論 2 381
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來衫仑,“玉大人梨与,你說我怎么就攤上這事∥挠” “怎么了粥鞋?”我有些...
    開封第一講書人閱讀 153,340評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長瞄崇。 經(jīng)常有香客問我呻粹,道長,這世上最難降的妖魔是什么苏研? 我笑而不...
    開封第一講書人閱讀 55,449評(píng)論 1 279
  • 正文 為了忘掉前任等浊,我火速辦了婚禮,結(jié)果婚禮上摹蘑,老公的妹妹穿的比我還像新娘筹燕。我一直安慰自己,他們只是感情好衅鹿,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,445評(píng)論 5 374
  • 文/花漫 我一把揭開白布撒踪。 她就那樣靜靜地躺著,像睡著了一般大渤。 火紅的嫁衣襯著肌膚如雪糠涛。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,166評(píng)論 1 284
  • 那天兼犯,我揣著相機(jī)與錄音忍捡,去河邊找鬼。 笑死切黔,一個(gè)胖子當(dāng)著我的面吹牛砸脊,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播纬霞,決...
    沈念sama閱讀 38,442評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼凌埂,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了诗芜?” 一聲冷哼從身側(cè)響起瞳抓,我...
    開封第一講書人閱讀 37,105評(píng)論 0 261
  • 序言:老撾萬榮一對情侶失蹤埃疫,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后孩哑,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體栓霜,經(jīng)...
    沈念sama閱讀 43,601評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,066評(píng)論 2 325
  • 正文 我和宋清朗相戀三年横蜒,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了胳蛮。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,161評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡丛晌,死狀恐怖仅炊,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情澎蛛,我是刑警寧澤抚垄,帶...
    沈念sama閱讀 33,792評(píng)論 4 323
  • 正文 年R本政府宣布,位于F島的核電站谋逻,受9級(jí)特大地震影響督勺,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜斤贰,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,351評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望次询。 院中可真熱鬧荧恍,春花似錦、人聲如沸屯吊。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,352評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽盒卸。三九已至骗爆,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間蔽介,已是汗流浹背摘投。 一陣腳步聲響...
    開封第一講書人閱讀 31,584評(píng)論 1 261
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留虹蓄,地道東北人犀呼。 一個(gè)月前我還...
    沈念sama閱讀 45,618評(píng)論 2 355
  • 正文 我出身青樓,卻偏偏與公主長得像薇组,于是被迫代替她去往敵國和親外臂。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,916評(píng)論 2 344

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