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

首頁 > 系統 > iOS > 正文

IOS 開發之自定義按鈕實現文字圖片位置隨意定制

2020-07-26 03:01:25
字體:
來源:轉載
供稿:網友

IOS 開發之自定義按鈕實現文字圖片位置隨意定制

可能有些看到這篇文章的朋友會覺得很不屑:“按鈕誰不會自定義?還需要看你的?” 也確實,按鈕是我們項目中最常見的控件之一,天天在使用。對于不同類型的按鈕,我們是否有更加簡便的方法來實現需求是我們需要做的。這里我提出自己的兩種方法,您可以對你自己平時自定義按鈕的方法做一下對比,看看哪種方法更加簡單。

多說一句,千萬不要覺得知識簡單,覺得自己會了,沒必要學習。'往往簡單的東西存在大智慧'(這個比給滿分),知識都是慢慢積累出來的。

按鈕是應用中最常見的,最基本的一個控件。按鈕的樣式多種多樣,系統默認樣式為左右結構,圖片在左邊,文字在右邊。系統按鈕完全無法滿足開發的需求,我們只能自己定制出想要的樣式。既包含文字又包含圖片的按鈕有下面四種樣式:

  • 圖片在上,文字在下
  • 圖片在左,文字在右
  • 圖片在下,文字在上
  • 圖片在右,文字在左

我們都知道,在按鈕中可以通過設置圖片和文字的內邊距(UIEdgeInsetsMake)來改變圖片和文字的位置來滿足我們的需求。當然這只是其中一個方法。還有一種方法是使用繼承,創建一個類繼承自UIButton,通過重寫layoutSubviews方法,來改變按鈕內部子控件的位置,從而達到我們的需求。 話不多說, 開整。

方法一:通過分類的方式實現

新建一個UIButton的分類,下面是具體聲明和實現

#import <UIKit/UIKit.h>// 定義一個枚舉(包含了四種類型的button)typedef NS_ENUM(NSUInteger, MKButtonEdgeInsetsStyle) {  MKButtonEdgeInsetsStyleTop, // image在上,label在下  MKButtonEdgeInsetsStyleLeft, // image在左,label在右  MKButtonEdgeInsetsStyleBottom, // image在下,label在上  MKButtonEdgeInsetsStyleRight // image在右,label在左};@interface UIButton (ImageTitleSpacing)/** * 設置button的titleLabel和imageView的布局樣式,及間距 * * @param style titleLabel和imageView的布局樣式 * @param space titleLabel和imageView的間距 */- (void)layoutButtonWithEdgeInsetsStyle:(MKButtonEdgeInsetsStyle)style            imageTitleSpace:(CGFloat)space;@end

再來看看實現文件

#import "UIButton+ImageTitleSpacing.h"@implementation UIButton (ImageTitleSpacing)- (void)layoutButtonWithEdgeInsetsStyle:(MKButtonEdgeInsetsStyle)style            imageTitleSpace:(CGFloat)space {  /**   * 知識點:titleEdgeInsets是title相對于其上下左右的inset,跟tableView的contentInset是類似的,   * 如果只有title,那它上下左右都是相對于button的,image也是一樣;   * 如果同時有image和label,那這時候image的上左下是相對于button,右邊是相對于label的;title的上右下是相對于button,左邊是相對于image的。   */  // 1. 得到imageView和titleLabel的寬、高  CGFloat imageWith = self.imageView.frame.size.width;  CGFloat imageHeight = self.imageView.frame.size.height;  CGFloat labelWidth = 0.0;  CGFloat labelHeight = 0.0;  if ([UIDevice currentDevice].systemVersion.floatValue >= 8.0) {    // 由于iOS8中titleLabel的size為0,用下面的這種設置    labelWidth = self.titleLabel.intrinsicContentSize.width;    labelHeight = self.titleLabel.intrinsicContentSize.height;  } else {    labelWidth = self.titleLabel.frame.size.width;    labelHeight = self.titleLabel.frame.size.height;  }  // 2. 聲明全局的imageEdgeInsets和labelEdgeInsets  UIEdgeInsets imageEdgeInsets = UIEdgeInsetsZero;  UIEdgeInsets labelEdgeInsets = UIEdgeInsetsZero;  // 3. 根據style和space得到imageEdgeInsets和labelEdgeInsets的值   /**    MKButtonEdgeInsetsStyleTop, // image在上,label在下    MKButtonEdgeInsetsStyleLeft, // image在左,label在右    MKButtonEdgeInsetsStyleBottom, // image在下,label在上    MKButtonEdgeInsetsStyleRight // image在右,label在左   */  switch (style) {    case MKButtonEdgeInsetsStyleTop:    {      imageEdgeInsets = UIEdgeInsetsMake(-labelHeight-space/2.0, 0, 0, -labelWidth);      labelEdgeInsets = UIEdgeInsetsMake(0, -imageWith, -imageHeight-space/2.0, 0);    }      break;    case MKButtonEdgeInsetsStyleLeft:    {      imageEdgeInsets = UIEdgeInsetsMake(0, -space/2.0, 0, space/2.0);      labelEdgeInsets = UIEdgeInsetsMake(0, space/2.0, 0, -space/2.0);    }      break;    case MKButtonEdgeInsetsStyleBottom:    {      imageEdgeInsets = UIEdgeInsetsMake(0, 0, -labelHeight-space/2.0, -labelWidth);      labelEdgeInsets = UIEdgeInsetsMake(-imageHeight-space/2.0, -imageWith, 0, 0);    }      break;    case MKButtonEdgeInsetsStyleRight:    {      imageEdgeInsets = UIEdgeInsetsMake(0, labelWidth+space/2.0, 0, -labelWidth-space/2.0);      labelEdgeInsets = UIEdgeInsetsMake(0, -imageWith-space/2.0, 0, imageWith+space/2.0);    }      break;    default:      break;  }  // 4. 賦值  self.titleEdgeInsets = labelEdgeInsets;  self.imageEdgeInsets = imageEdgeInsets;}@end

使用方法:只需要新建一個分類將上面的代碼拷貝,直接導入到需要使用的類中,調用方法就可以了,具體見下

// 導入頭文件#import "UIButton+ImageTitleSpacing.h"http:// 我們隨意創建一個按鈕比如button,在設置完按鈕的圖片、標題和frame后,只需要加上如下代碼:[button layoutButtonWithEdgeInsetsStyle: 這里填樣式 imageTitleSpace: 這里填寫圖片和文字的間距];

這樣是不是很方便呢?

方法二:通過繼承的方式實

新建一個繼承自UIButton的類,重寫layoutSubviews 方法,自己設置圖片和文字的位置。

#import "TSSquareButton.h"@implementation TSSquareButton- (instancetype)initWithFrame:(CGRect)frame {  if (self = [super initWithFrame:frame]) {    // 設置圖片的其他屬性    self.titleLabel.textAlignment = NSTextAlignmentCenter;    self.titleLabel.font = [UIFont systemFontOfSize:12.0];    [self setBackgroundColor:[UIColor whiteColor]];    [self setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];  }  return self;}// 重寫layoutSubviews方法,手動設置按鈕子控件的位置- (void)layoutSubviews {  [super layoutSubviews];  self.imageView.TS_width = self.TS_width * 0.4;  self.imageView.TS_height = self.imageView.TS_width;  self.imageView.TS_y = self.TS_height * 0.25;  self.imageView.TS_centerX = self.TS_width * 0.5;  self.titleLabel.TS_width = self.TS_width;  self.titleLabel.TS_y = self.imageView.TS_buttom ;  self.titleLabel.TS_height = 25;  self.titleLabel.TS_x = 0;}@end

兩種方式運行結果

總結:

至此,設置圖片的兩種方法就已經講完了。對比一下:

第一種通過分類的方式設置按鈕非常方便,只需要一行代碼就足夠了,不需要我們自己計算UIEngeInsetsMake,適用于純代碼創建的按鈕。 如果是Xib創建的按鈕就用不了了。

第二種通過繼承的方式重寫layoutSubviews的方式設置按鈕好處是既適用于純代碼創建的按鈕,也適用于Xib創建的按鈕,但是這種方法有一定的局限性,它只適用于同一類型的按鈕。一類比如我一個界面中有幾種不同類型的按鈕,這時候就需要我們創建不同的繼承UIButton 的按鈕類,在layoutSubviews設置不同的位置關系。這樣就相對復雜了。

兩種方法各有利弊,各位可以根據自己的實際情況來選擇使用。當然設置按鈕圖片和文字的位置并不止這兩種方法,還有其他更好的方法等著我們去發現。如果你有什么更好的建議,也可以聯系我,我們一同探討學習。

 感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久精品视频在线观看| 97视频网站入口| 精品国偷自产在线视频| 亚洲第一网站男人都懂| 日韩美女在线观看| 欧美日韩午夜激情| 亚洲自拍另类欧美丝袜| 欧美高清在线播放| 久久精品视频导航| 欧美一级大片在线免费观看| 久久久久久久国产精品视频| 久久999免费视频| 亚洲自拍另类欧美丝袜| 久久久久久久久久国产| 欧美日韩国产激情| 久久久久久久av| 2019日本中文字幕| 国产精品久久久久久久app| 日韩精品高清在线观看| 国产精品久久一区主播| 国产免费亚洲高清| 色综合久久中文字幕综合网小说| 一区二区三区视频在线| 欧美性猛交xxxx富婆| 45www国产精品网站| 亚洲欧美激情视频| 伊人伊人伊人久久| 欧美午夜无遮挡| 国产精品久久一区| 国产一区二区黑人欧美xxxx| 在线观看免费高清视频97| 久久999免费视频| 亚洲精品美女久久久| 国模极品一区二区三区| 欧美激情精品久久久久久大尺度| 亚洲人在线视频| 在线视频国产日韩| 国产精品91免费在线| 久久精品国产视频| 国产69精品99久久久久久宅男| 国产成人拍精品视频午夜网站| 精品av在线播放| 在线观看久久av| 国产欧美va欧美va香蕉在线| 日本精品在线视频| 国产偷亚洲偷欧美偷精品| 亚洲国产黄色片| 精品国内产的精品视频在线观看| 色七七影院综合| 欧美日韩亚洲成人| 国产精品久久久久aaaa九色| 欧美主播福利视频| 正在播放亚洲1区| 欧美激情按摩在线| 亚洲人成网站777色婷婷| 亚洲韩国日本中文字幕| 久久视频国产精品免费视频在线| 国产精品入口免费视频一| 亚洲福利视频在线| 国产精品va在线播放我和闺蜜| 欧美性视频在线| 国产91对白在线播放| 久久激情五月丁香伊人| 色综合色综合久久综合频道88| 国产精品扒开腿做爽爽爽的视频| 精品国内自产拍在线观看| 欧洲美女7788成人免费视频| 久久影视电视剧免费网站清宫辞电视| 欧美自拍大量在线观看| 国产视频综合在线| 最近更新的2019中文字幕| 中文字幕久久久av一区| 欧美成人亚洲成人| 狠狠久久五月精品中文字幕| 精品久久久999| 亚洲精品欧美一区二区三区| 欧美精品免费播放| 欧美激情手机在线视频| 日韩电影第一页| 久久露脸国产精品| 久久精品小视频| 国产精品久久久精品| 91国内在线视频| 国产亚洲精品va在线观看| 亚洲国产精品久久| 久久久久久久国产精品| 国产成人亚洲综合91| 久久久久久久久久久久av| 欧美日韩国产成人高清视频| 午夜剧场成人观在线视频免费观看| 日本一区二区在线播放| 国产精品视频中文字幕91| 欧美日韩在线看| 成人午夜一级二级三级| 国产成人一区二区三区| 亚洲第一网站免费视频| 国产精品嫩草影院一区二区| 色综合91久久精品中文字幕| 精品国产91久久久久久老师| 日韩av男人的天堂| 4k岛国日韩精品**专区| 中文字幕精品国产| 深夜福利一区二区| 国产成人在线播放| 国产精品成人av性教育| 日韩av在线直播| 国产欧美日韩高清| 国产99久久精品一区二区永久免费| 91高清免费视频| 久久免费国产精品1| 国产精品久久婷婷六月丁香| 欧洲精品在线视频| 久久久91精品国产一区不卡| 欧美剧在线观看| 97超视频免费观看| 亚洲男人的天堂在线播放| 国产精品69av| 欧美日韩福利视频| 久久综合久久88| 国内外成人免费激情在线视频| 日本a级片电影一区二区| 国产精品白嫩初高中害羞小美女| 日韩av电影院| 国内精品久久久久影院 日本资源| 成人欧美在线视频| 琪琪第一精品导航| 欧美又大又硬又粗bbbbb| 欧美片一区二区三区| 亚洲精品v天堂中文字幕| 欧美日韩综合视频| 国产精品久久久久久久午夜| 国产极品精品在线观看| 亚洲欧美中文在线视频| 欧美成人精品不卡视频在线观看| 韩国三级电影久久久久久| 91中文在线视频| 久久成年人免费电影| 久久精品小视频| 久久久久久久久久久免费精品| 欧美寡妇偷汉性猛交| 久久久影视精品| 欧美日韩久久久久| 精品国产一区二区三区久久久狼| 亚洲欧美制服第一页| 久久久99久久精品女同性| 色播久久人人爽人人爽人人片视av| 美女视频黄免费的亚洲男人天堂| 欧美另类老女人| 国产欧美在线看| 亚洲大胆人体在线| 日韩精品中文字幕在线观看| 国产精品亚洲片夜色在线| 亚洲免费小视频| 日韩视频中文字幕| 精品视频久久久久久| 久久久久久久久久国产| 91精品国产91久久久久久最新| 亚洲人高潮女人毛茸茸| 国产99久久精品一区二区 夜夜躁日日躁| 国产日韩精品在线| 欧美在线中文字幕| 欧美中文在线观看国产| 国产亚洲欧美一区| 欧美大片免费观看|