亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > iOS > 正文

iOS如何將UIButton中的圖片與文字上下對齊詳解

2019-10-21 18:44:09
字體:
來源:轉載
供稿:網友

前言

相信每位iOS開發者都知道在UIButton中可以設置圖片和文字,也經常見到同時設置有圖片和下方提示文字的按鈕,但是當我自己去對圖片按鈕添加提示文字的時候,卻發現這并不是想象中的那么簡單。怎么不簡單呢?下面來一起看看詳細的介紹吧。

設置圖片和文字

如示例代碼:

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方法分別為按鈕設置圖片和文字信息,但是會發現設置完成以后我們的圖片和文字并沒有重合排列,也沒有上下排列,而是一個左右排列的樣子。

uibutton,圖片文字上下,ios,文字居中,設置文字
設置圖片和文字

說到這里,肯定會有人想到設置圖片和文字的frame來進行處理,而且我們也確實可以通過UIButton的對象獲取到對應的imageView和titleLabel,但是如果經過測試的話,你就會發現這是一個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)}

修改為這樣以后,運行程序,會發現對應的視圖沒有任何變化。

uibutton,圖片文字上下,ios,文字居中,設置文字
添加frame設置

UIEdgeInsets

查看UIButton的屬性,我們會找到titleEdgeInsets和imageEdgeInsets兩個屬性。修改這兩個屬性,可以實現我們想要的效果。

titleEdgeInsets和imageEdgeInsets都是UIEdgeInsets的對象,我們先說一下UIEdgeInsets的幾個屬性的具體效果。

我們知道,UIEdgeInsets有top,left,bottom,right幾個屬性,但是通過測試,就會發現設置了top以后自己的y坐標并沒有增加響應的距離,而是增加了1/2,那么它們到底應該如何計算呢?

當設置了top以后,其實就是相當于view的上邊緣向下移動了相應的距離。用在title中,如果titleLabel的frame(50, 50, 24, 24);那么Button的上下邊緣應該分別是0和124,因為正常情況下titleLabel必然處于Button的中間位置。當設置了titleEdgeInsets的top為10以后,相當于button的上下坐標為10,124,則titleLabel的坐標就變成了(50, 55, 24, 24),也就是上下邊緣變為了55和79, 向下移動了5個點。

經過計算可以得出,如果要將文字移動到圖片的下方,需要設置titleEdgeInsets和imageEdgeInsets,且分別設置為
若titleLabel為 w1,h1, imageView為w2,h2, 上下間距為space

titleEdgeInsets = (h2 + space, - w2, 0, 0)imageEdgeInsets = (-h1 - 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.sizevar titleSize:CGSize = button.titleLabel!.frame.sizebutton.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)}

則可實現我們要求的效果:

uibutton,圖片文字上下,ios,文字居中,設置文字
設置insets

注意:如果設置了button的frame,而且button的寬度不足以同時顯示圖片和文字的大小的話,titleLabel的size將會獲取錯誤。所以如果需要設置frame,建議先將button的寬度設置為frame.size.width * 2, 等titleEdgeInsets和imageEdgeInsets全部設置完成以后再重新設置frame。

總結

以上就是這篇文章的全部內容了,本文還有許多不足,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VEVB武林網的支持。


注:相關教程知識閱讀請移步到IOS開發頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
成人网在线免费观看| 亚洲另类图片色| 亚洲人成网站777色婷婷| 青青久久aⅴ北条麻妃| 欧美激情国产精品| 国产午夜精品美女视频明星a级| 国产一区二区三区三区在线观看| 亚洲欧美在线看| 精品福利在线视频| 日韩av大片免费看| 国产精品久久99久久| 91免费看片网站| 欧美黄色片在线观看| 中文字幕亚洲欧美在线| 久久国产精品网站| 欧美日韩第一页| 亚洲精品久久久久中文字幕二区| 欧美综合一区第一页| 日韩在线资源网| 日韩大陆欧美高清视频区| 久久九九精品99国产精品| 6080yy精品一区二区三区| 国产亚洲a∨片在线观看| 欧美专区在线播放| 国产精品午夜视频| 久久久国产精品视频| 亚洲а∨天堂久久精品9966| 清纯唯美日韩制服另类| 97色在线观看免费视频| 高清欧美电影在线| 国产网站欧美日韩免费精品在线观看| 免费不卡在线观看av| 7777精品久久久久久| 欧美成人手机在线| 亚洲精品永久免费精品| 亚洲国产精品电影在线观看| 日韩精品中文在线观看| 亚洲欧美日韩国产成人| 正在播放欧美视频| 色综合五月天导航| 中文字幕日韩av电影| 欧洲亚洲免费在线| 国产69久久精品成人看| 国产一区二区三区久久精品| 国产精品日韩欧美| 不用播放器成人网| 亚洲深夜福利网站| 国产69精品久久久久9| 国内精品国产三级国产在线专| 欧美高清视频一区二区| 国产69精品久久久久9999| 欧美成人剧情片在线观看| 国产精品热视频| 国产精品444| 国内精久久久久久久久久人| 午夜精品三级视频福利| 国产视频999| 国产精品aaaa| 国产精品久久久久久久久久| 国产欧美日韩精品专区| 清纯唯美日韩制服另类| 97精品一区二区视频在线观看| 久久精品91久久久久久再现| 欧美精品video| 国产成人精品免高潮在线观看| 国产精品色婷婷视频| 中文字幕在线精品| 久久午夜a级毛片| 51精品在线观看| 亚洲a∨日韩av高清在线观看| 日本午夜精品理论片a级appf发布| 亚洲国产精品高清久久久| 亚洲国产精品系列| 精品久久久久久久久久久久久| 日韩成人激情视频| 日韩av观看网址| 91精品视频网站| 日本午夜在线亚洲.国产| 色综合影院在线| 欧美日韩国产一区在线| 精品国产电影一区| 精品一区二区亚洲| 91亚洲精品久久久久久久久久久久| 日韩av在线一区二区| 国产成人精品综合| 久久亚洲国产精品| 欧美电影免费观看| 国产精品视频26uuu| 这里只有视频精品| 黑人狂躁日本妞一区二区三区| 亚洲美女喷白浆| 国产精品免费一区豆花| 欧美色播在线播放| 日韩视频欧美视频| 久久久久久中文| 国产精品热视频| 亚洲一区二区三区四区视频| 懂色aⅴ精品一区二区三区蜜月| 日韩精品视频免费在线观看| 国产99久久精品一区二区永久免费| 精品欧美一区二区三区| 国产精品久久久久影院日本| 在线视频欧美日韩精品| 久久国产一区二区三区| 国产欧美va欧美va香蕉在线| 亚洲最大成人在线| 欧美美女操人视频| 亚洲欧美中文日韩v在线观看| 日韩有码在线视频| 日韩免费观看在线观看| 亚洲人成网在线播放| 欧美激情视频免费观看| 亚洲欧美另类中文字幕| 国产精品色婷婷视频| 日韩欧美亚洲成人| 欧美成人四级hd版| 国产精品igao视频| 欧美国产精品va在线观看| 奇米4444一区二区三区| 国产日韩欧美在线视频观看| 久久久噜久噜久久综合| 欧美国产日韩一区二区三区| 亚洲国产高潮在线观看| 九九精品视频在线观看| 成人一区二区电影| 国产精品看片资源| 一本色道久久综合狠狠躁篇怎么玩| 国产欧美一区二区三区久久| 欧美综合一区第一页| 在线观看日韩视频| 黑人与娇小精品av专区| 18久久久久久| 欧美国产视频日韩| 日本久久久a级免费| 国产精品丝袜久久久久久不卡| 丝袜情趣国产精品| 精品久久香蕉国产线看观看gif| 欧美成人精品xxx| 精品久久久91| 欧美激情亚洲一区| 在线观看日韩av| 在线精品视频视频中文字幕| 日韩av快播网址| 91青草视频久久| 久久久精品美女| 午夜欧美大片免费观看| 国产一区二区三区视频| 成人欧美在线观看| 国产主播欧美精品| 亚洲色图狂野欧美| 亚洲第一视频网站| 色综合久久久久久中文网| 色中色综合影院手机版在线观看| 久久影视电视剧凤归四时歌| 国产丝袜精品第一页| 色噜噜狠狠狠综合曰曰曰88av| 国产精品观看在线亚洲人成网| 91精品国产91久久久久福利| 国产欧美亚洲视频| www.国产精品一二区| 日韩av电影手机在线| 91精品视频在线| 91精品国产乱码久久久久久久久| 精品久久久久久国产91|