代码地址如下:
http://www.demodashi.com/demo/11606.html

前记

在开发中,我们经常会遇到这么一种情况,就是一个按钮上面有图片也有文字,但是往往设计并不是我们想要的那种,比如可能图片在上,文字在下,或者图片在左,文字在右,关键是还有一定的距离,并不是系统默认UIButton中,图片和文字的间距。当然,这调整图片和文字的距离的小事,是难不倒大家的,因为大家都知道,在UIButton中,有这么两个属性titleEdgeInsetsimageEdgeInsets

关于属性

关于titleEdgeInsetsimageEdgeInsets这两个属性,简单介绍下:
titleEdgeInsetstitle相对于其上下左右的inset,跟tableViewcontentInset是类似的,如果只有title,那它上下左右都是相对于button的,imageEdgeInsets也是一样
如果同时有imagetitle,那这时候image的上左下是相对于button,右边是相对于title的;title的上右下是相对于button,左边是相对于image的,也就是说image是默认居左的。
通过以上两个属性,可以很轻松的实现文字图片的位置及距离的调整,如果每次在用的时候,都去重新写一片,难免会很麻烦,鉴于此,之前在谋篇博客中(具体忘了,原博主看到请勿见怪),看到过用category封装的,于是我在项目中,也写了一个category,其中也列举了四种不同的枚举来表现其不同的场景

枚举类型

// 定义一个枚举(包含了四种类型的button)
typedef NS_ENUM(NSUInteger, GLButtonEdgeInsetsStyle) {GLButtonEdgeInsetsStyleTop, // image在上,label在下GLButtonEdgeInsetsStyleLeft, // image在左,label在右GLButtonEdgeInsetsStyleBottom, // image在下,label在上GLButtonEdgeInsetsStyleRight // image在右,label在左
};

并且定义了一个简单使用的方法:

/***  设置button的titleLabel和imageView的布局样式,及间距**  @param style titleLabel和imageView的布局样式*  @param space titleLabel和imageView的间距*/
- (void)layoutButtonWithEdgeInsetsStyle:(GLButtonEdgeInsetsStyle)styleimageTitleSpace:(CGFloat)space;

其中space是指图片文字之间的间距,style对应上面的枚举,可以针对性的选择

具体实现方法

- (void)layoutButtonWithEdgeInsetsStyle:(GLButtonEdgeInsetsStyle)styleimageTitleSpace:(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.image.size.width;CGFloat imageHeight = self.imageView.image.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和labelEdgeInsetsUIEdgeInsets imageEdgeInsets = UIEdgeInsetsZero;UIEdgeInsets labelEdgeInsets = UIEdgeInsetsZero;// 3. 根据style和space得到imageEdgeInsets和labelEdgeInsets的值switch (style) {case GLButtonEdgeInsetsStyleTop:{            imageEdgeInsets = UIEdgeInsetsMake(-labelHeight-space/2.0, 0, 0, -labelWidth);labelEdgeInsets = UIEdgeInsetsMake(0, -imageWith, -imageHeight-space/2.0, 0);}break;case GLButtonEdgeInsetsStyleLeft:{imageEdgeInsets = UIEdgeInsetsMake(0, -space/2.0, 0, space/2.0);labelEdgeInsets = UIEdgeInsetsMake(0, space/2.0, 0, -space/2.0);}break;case GLButtonEdgeInsetsStyleBottom:{imageEdgeInsets = UIEdgeInsetsMake(0, 0, -labelHeight-space/2.0, -labelWidth);labelEdgeInsets = UIEdgeInsetsMake(-imageHeight-space/2.0, -imageWith, 0, 0);}break;case GLButtonEdgeInsetsStyleRight:{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;
}

实现效果

其实思路很简单,这里只是简单封装了下。

项目文件截图:

iOS UIButton文字和图片间距随意调整

代码地址如下:
http://www.demodashi.com/demo/11606.html

注:本文著作权归作者,由demo大师发表,拒绝转载,转载需要作者授权

iOS UIButton文字和图片间距随意调整相关推荐

  1. iOS UIButton文字与图片交换位置

    UIButton默认,图片居左,文字在右,垂直居中显示,文字与图片没有间距,如下图: 可以通过设置UIButton中的titleEdgeInsets和imageEdgeInsets改变按钮的image ...

  2. wps图片与图片间距怎么调整_wps图片与图片间距怎么调整_微信图文排版,字间距,行间距,怎么调整合适?......

    常见的有两种排版,一种传统报纸形式,另一种就是大家常用的新媒体排版形式. 行间距 通常图片和文字之间要留空一行,这样阅读体验不会显得那么乏味,枯燥.留空一行显得简洁更加美观,能大大提升阅读者继续往下看 ...

  3. iOS UIButton 文字图片上下左右布局

    例如文字在左 图片在右,iOS 9 之后一句话搞定 backBtn.semanticContentAttribute = UISemanticContentAttributeForceRightToL ...

  4. wps图片与图片间距怎么调整_怎么样在WPS文档中将图片的中间间距拉?

    2011-05-31 如何删除没有回车符的空行?如何删 选中WORD整个文档,进行"格式/段落/缩进和间距/间距/段前/0行/段后/0行/确定"操作,即可将段前和段后没有回车符的空 ...

  5. wps图片与图片间距怎么调整_wps文档插入图片怎样中间空隙 具体方法介绍

    1."word里插入图片,默认图片与图片之间是有空隙的.点击导航 [页面布局].点击段落右下角小箭头. 2.打开段落设置.行距:选择"单倍行距",然后把下面"如 ...

  6. UIButton的竖排图片和文本

    UIButton的竖排图片和文本 UIButton的竖排图片和文本第一想法:实现思路第二种方法UIContentHorizontalAlignment/UIControlContentVertical ...

  7. iOS UIButton 图片文字上下垂直布局 解决方案

    iOS UIButton 图片文字上下垂直布局 解决方案 参考文章: (1)iOS UIButton 图片文字上下垂直布局 解决方案 (2)https://www.cnblogs.com/yajunL ...

  8. ios 按钮文字下划线_iOS - UIButton设置文字标题下划线以及下划线颜色

    创建button设置可以折行显示 - (void)viewDidLoad { [super viewDidLoad]; UIButton * button = [[UIButton alloc] in ...

  9. ai字体行间距怎么调整_ai怎么调整文字间距- ai调整行间距的详细教程

    ai 怎么调整文字间距 ? ai 调整行间距的详细教程 AI 作为一款矢量的绘图软件挺受青睐,然而使用者都会发觉它无法像文档一样随意调节字 体的间距和行距,也就是缺少了文字排版的功能,我在那个地点简单 ...

最新文章

  1. 24GHz和77GHz毫米波雷达技术细节
  2. 在线实时大数据平台Storm单机部署
  3. Flutter之导url_launcher包提示 A dependency may only have one source.
  4. vue-router 路由跳转
  5. JAVA进阶教学之(Date日期的处理)
  6. 库克:苹果商店收取30%佣金是应该的
  7. SQL2005 远程连接问题解决方法
  8. Ubuntu下libmodbus的应用
  9. Java 常量池详解(一)字符串常量池
  10. 基于Multism的高频小信号谐振放大器仿真研究
  11. 如何免费的把 PDF 转换为 Word文档?
  12. 【JAVA笔记】JAVA调用同一个包里的不同类的方法:
  13. Android开发笔记(一百八十六)管理SQLite的利器——应用检查器App Inspection
  14. 如何下载酷6、土豆、优酷、56视频并转化格式进行播
  15. 杭电出了“王炸班”!考研3个清北8个浙大,就业人均起薪30万+
  16. 【已解决】LaTeX调整图片大小
  17. 飞天遁地、来去自如?Oracle数据库秉承技术当先,用户也来说说看
  18. php更换鼠标指针详细,鼠标指针替换教程(修正版 )
  19. 利用FFmpeg解决视频音画不同步的问题
  20. c#,c++,qt中多线程访问UI控件线程的问题汇总

热门文章

  1. python空行拼接字符串_在python中的每一个空行插入一个新的行字符串
  2. python同时输入多个变量_python同时给多个变量赋值
  3. IP协议(RFC791)-IP包格式
  4. vector与list的接口介绍与如何使用以及区别,附代码。
  5. python 将列表值赋予函数_python把空列表作为函数默认参数,可是有坑的
  6. Swagger原理解析
  7. Java高级开发工程师面试考纲
  8. 分页——SQL Server 对比 MySQL
  9. SQL Server: create table sql script
  10. 分区表理论解析(下):SQL Server 2k52k8系列(二)