這篇文章將為大家詳細(xì)講解有關(guān)iOS怎么將UIButton中的圖片與文字上下對齊,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
創(chuàng)新互聯(lián)主營圖們網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營網(wǎng)站建設(shè)方案,app軟件開發(fā)公司,圖們h5小程序開發(fā)搭建,圖們網(wǎng)站營銷推廣歡迎圖們等地區(qū)企業(yè)咨詢
設(shè)置圖片和文字
如示例代碼:
func initView() -> Void { var button:UIButton = UIButton(frame: CGRectMake(100, 200, 100, 100)) button.setImage(UIImage(named: "button.png"), forState: UIControlState.Normal) button.setTitle("按鈕", forState: UIControlState.Normal) button.backgroundColor = UIColor.blueColor() self.view.addSubview(button) }
我們可以通過UIButton的setTitle和setImage方法分別為按鈕設(shè)置圖片和文字信息,但是會發(fā)現(xiàn)設(shè)置完成以后我們的圖片和文字并沒有重合排列,也沒有上下排列,而是一個左右排列的樣子。
設(shè)置圖片和文字
說到這里,肯定會有人想到設(shè)置圖片和文字的frame來進(jìn)行處理,而且我們也確實可以通過UIButton的對象獲取到對應(yīng)的imageView和titleLabel,但是如果經(jīng)過測試的話,你就會發(fā)現(xiàn)這是一個trike的方法,而且是不生效的。
func initView() -> Void { var button:UIButton = UIButton(frame: CGRectMake(100, 200, 100, 100)) button.setImage(UIImage(named: "button.png"), forState: UIControlState.Normal) button.setTitle("按鈕", forState: UIControlState.Normal) button.backgroundColor = UIColor.blueColor() button.titleLabel?.frame = CGRectMake(20, 0, 30, 30) button.imageView?.frame = CGRectMake(0, 0, 20, 20) self.view.addSubview(button) }
修改為這樣以后,運(yùn)行程序,會發(fā)現(xiàn)對應(yīng)的視圖沒有任何變化。
添加frame設(shè)置
UIEdgeInsets
查看UIButton的屬性,我們會找到titleEdgeInsets和imageEdgeInsets兩個屬性。修改這兩個屬性,可以實現(xiàn)我們想要的效果。
titleEdgeInsets和imageEdgeInsets都是UIEdgeInsets的對象,我們先說一下UIEdgeInsets的幾個屬性的具體效果。
我們知道,UIEdgeInsets有top,left,bottom,right幾個屬性,但是通過測試,就會發(fā)現(xiàn)設(shè)置了top以后自己的y坐標(biāo)并沒有增加響應(yīng)的距離,而是增加了1/2,那么它們到底應(yīng)該如何計算呢?
當(dāng)設(shè)置了top以后,其實就是相當(dāng)于view的上邊緣向下移動了相應(yīng)的距離。用在title中,如果titleLabel的frame(50, 50, 24, 24);那么Button的上下邊緣應(yīng)該分別是0和124,因為正常情況下titleLabel必然處于Button的中間位置。當(dāng)設(shè)置了titleEdgeInsets的top為10以后,相當(dāng)于button的上下坐標(biāo)為10,124,則titleLabel的坐標(biāo)就變成了(50, 55, 24, 24),也就是上下邊緣變?yōu)榱?5和79, 向下移動了5個點(diǎn)。
經(jīng)過計算可以得出,如果要將文字移動到圖片的下方,需要設(shè)置titleEdgeInsets和imageEdgeInsets,且分別設(shè)置為
若titleLabel為 w1,h2, imageView為w2,h3, 上下間距為space
titleEdgeInsets = (h3 + space, - w2, 0, 0) imageEdgeInsets = (-h2 - space, w1)
如上述例子若改為:
func initView() -> Void { var button:UIButton = UIButton(frame: CGRectMake(100, 200, 100, 100)) button.setImage(UIImage(named: "button.png"), forState: UIControlState.Normal) button.setTitle("按鈕", forState: UIControlState.Normal) button.backgroundColor = UIColor.blueColor() var imageSize:CGSize = button.imageView!.frame.size var titleSize:CGSize = button.titleLabel!.frame.size button.titleEdgeInsets = UIEdgeInsets(top: 0, left:-imageSize.width, bottom: -imageSize.height - 5, right: 0) button.imageEdgeInsets = UIEdgeInsets(top: -titleSize.height - 5, left: 0, bottom: 0, right: -titleSize.width) self.view.addSubview(button) }
則可實現(xiàn)我們要求的效果:
設(shè)置insets
注意:如果設(shè)置了button的frame,而且button的寬度不足以同時顯示圖片和文字的大小的話,titleLabel的size將會獲取錯誤。所以如果需要設(shè)置frame,建議先將button的寬度設(shè)置為frame.size.width * 2, 等titleEdgeInsets和imageEdgeInsets全部設(shè)置完成以后再重新設(shè)置frame。
關(guān)于“iOS怎么將UIButton中的圖片與文字上下對齊”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。