自定义UIButton
偶尔逛简书能看见很多值得记下来的东西,有的接触过有的没接触过,接触过的也可能过段时间就忘记了,再上手的时候可能手足无措,所以决定有些觉得值得记下来的东西还是记录一下。博客是个好地方,因为很多人都能搜索到,所以迫使自己要认真点写,不然就很丢人了,所以在这里记录一些东西可能是对自己而言以后再次翻看最清晰的记录了,推荐大家都可以写一下,就当做笔记了,这样比收藏别人的文章更好,因为别人的思路转换为自己的东西还是需要一个过程的,自己把自己的领悟写下来就是这个过程。
写了这么多废话,下面开始主题了:
第一种方式:子类重新布局
很简单就直接上代码了:
继承UIButton,我常用的类前缀是AT,所以自定义按钮就是ATButton了,我们在ATButton重写layoutSubviews方法。
一般常见的样式就是图片在上文字标题在下,或者图片在右标题文字在左,图片在右文字在左就不用说了吧,默认样式,图片在下文字在上至今没见过,不过也不难实现,但是这里就不写了,只写前两种,会了前两种最后一种也就不难懂了。
图片在上文字标题在下
ATButton.m
//更改上下方向图片和文字的位置
- (void)layoutSubviews{
[super layoutSubviews]; CGRect imageRect = self.imageView.frame;
imageRect.origin.x = self.frame.size.width * 0.5 - imageRect.size.width * 0.5;
imageRect.origin.y = self.frame.size.height * 0.5 - imageRect.size.height; CGRect titleRect = self.titleLabel.frame;
titleRect.origin.x = self.frame.size.width * 0.5 - titleRect.size.width * 0.5;
titleRect.origin.y = self.frame.size.height * 0.5 ; self.imageView.frame = imageRect;
self.titleLabel.frame = titleRect;
}
控制器:
ATButton *btn = [[ATButton alloc] init];
[btn setBackgroundColor:[UIColor greenColor]];
[btn setFrame:CGRectMake(, , , )];
[btn setTitle:@"按钮" forState:UIControlStateNormal];
[btn setTitleColor:[UIColor redColor] forState:UIControlStateNormal];
[btn setImage:[UIImage imageNamed:@"mainCellCaiClick"] forState:UIControlStateNormal];
[btn addTarget:self action:@selector(btnClick:) forControlEvents:UIControlEventTouchUpInside];
[self.view addSubview:btn];
效果图:

图片在右文字标题在左
ATButton.m
//更改左右方向图片和文字的位置
- (void)layoutSubviews
{
[super layoutSubviews]; CGRect imageRect = self.imageView.frame;
imageRect.origin.x = self.frame.size.width * 0.5 ;
imageRect.origin.y = self.frame.size.height * 0.5 - imageRect.size.height * 0.5; CGRect titleRect = self.titleLabel.frame;
titleRect.origin.x = self.frame.size.width * 0.5 - titleRect.size.width;
titleRect.origin.y = self.frame.size.height * 0.5 - titleRect.size.height * 0.5; self.imageView.frame = imageRect;
self.titleLabel.frame = titleRect; }
控制器:
ATButton *btn = [[ATButton alloc] init];
[btn setBackgroundColor:[UIColor greenColor]];
[btn setFrame:CGRectMake(, , , )];
[btn setTitle:@"按钮" forState:UIControlStateNormal];
[btn setTitleColor:[UIColor redColor] forState:UIControlStateNormal];
[btn setImage:[UIImage imageNamed:@"mainCellCaiClick"] forState:UIControlStateNormal];
[btn addTarget:self action:@selector(btnClick:) forControlEvents:UIControlEventTouchUpInside];
[self.view addSubview:btn];
效果图:(我都是让它们居中显示的,如果你想改的话调一下位置也很容易)

第二种方式:EdgeInsets(不需要创建子类直接在控制器两行代码更改位置)
图片在右文字标题在左
UIButton *btn = [[UIButton alloc] init];
[btn setBackgroundColor:[UIColor greenColor]];
[btn setFrame:CGRectMake(, , , )];
[btn setTitle:@"按钮" forState:UIControlStateNormal];
[btn setTitleColor:[UIColor redColor] forState:UIControlStateNormal];
[btn setImage:[UIImage imageNamed:@"mainCellCaiClick"] forState:UIControlStateNormal];
[btn addTarget:self action:@selector(btnClick:) forControlEvents:UIControlEventTouchUpInside];
btn.imageEdgeInsets = UIEdgeInsetsMake(, btn.frame.size.width * 0.5, , );
btn.titleEdgeInsets = UIEdgeInsetsMake(, -btn.frame.size.width + (btn.frame.size.width * 0.5 - btn.titleLabel.frame.size.width), , );
[self.view addSubview:btn];
效果图:

图片在上文字标题在下
UIButton *btn = [[UIButton alloc] init];
[btn setBackgroundColor:[UIColor greenColor]];
[btn setFrame:CGRectMake(, , , )];
[btn setTitle:@"按钮" forState:UIControlStateNormal];
[btn setTitleColor:[UIColor redColor] forState:UIControlStateNormal];
[btn setImage:[UIImage imageNamed:@"mainCellCaiClick"] forState:UIControlStateNormal];
[btn addTarget:self action:@selector(btnClick:) forControlEvents:UIControlEventTouchUpInside];
btn.imageEdgeInsets = UIEdgeInsetsMake(-(btn.imageView.frame.size.height),btn.frame.size.width * 0.5 - btn.imageView.frame.size.width * 0.5, , );
btn.titleEdgeInsets = UIEdgeInsetsMake(, -btn.titleLabel.frame.size.width * 0.5, -(btn.titleLabel.frame.size.height), );
[self.view addSubview:btn];
效果图:

OK,就是这么多了,最后说一下UIEdgeInsetsMake():它的参数顺序有点奇怪,是上左下右,怎么用呢?这么记比较简单:比如说你想让按钮中的图片向左移10,你就在第二个参数写10,前面加负号就OK了,其他位置都一样,这样用比较容易理解一些,也比较容易记。
github:https://github.com/alan12138/Custom-Control
自定义UIButton的更多相关文章
- IOS实现UIButton图文混排、自定义按钮按下和正常状态下不同的背景颜色、根据文字长度自定义UIButton长度
在一些项目中,我们需要自定义自己的UIButton,使Button上面同时具有图片和文字描述,实现自定义UIButton的图文混排. 首先我们需要定义一个继承自UIButton的类,同时实现自己的in ...
- iOS 自定义UIButton(图片和文字混合)
// UIApplicationDelegate .h文件 #import <UIKit/UIKit.h> @interface AppDelegate : UIResponder &l ...
- iOS 自定义UIButton
工作中有一个点击button更新button上文案的需求,用自定义了button可以很简单的实现的这个需求 首先写个自定义的button CustomButton.h #import <UIKi ...
- 第二十篇、自定义UIButton(设置title和image的位置)
#import "CustomButton.h" #define ImageW 15 #define ImageH 15 #define KRadio 0.75 @implemen ...
- 自定义UIButton 实现图片和文字 之间距离和不同样式
喜欢交朋友的加:微信号 dwjluck2013 1.UIButton+ImageTitleSpace.h #import <UIKit/UIKit.h> // 定义一个枚举(包含了四种类型 ...
- ios自定义UIButton内部空间Rect
- 关于UIButton嵌入到UIView点击无反应问题的解决方法和delegate的简单用法示例(转载)
做项目封装UIView的时候碰到的问题,没想到有个哥们儿还写成博客,特此收藏! 问题是这样的,几个界面用到同一个自定义返回按钮,于是就想着把这个按钮单独封装起来,添加一个UIView类,在里面自定义U ...
- ios控件自定义指引
转载自:http://bbs.9ria.com/thread-256747-1-1.html 一直以来都想写点什么,做点有意义的事,从今天开始我将会把自己在这一年的学习和应用IOS开发中的学习心得和体 ...
- iOS-UI控件之UIButton
---恢复内容开始--- UIButton 既可以显示图片,又可以显示文字,还能随时调整内部位置 系统自带尺寸 storyboard内部调整UIButton属性 状态 监听按钮点击事件 凡是继承自UI ...
随机推荐
- Lisk沙箱漏洞分析及解决方案
背景 比特股的创始人Daniel Larimer质疑了lisk系统中的一系列问题,绝大多数都被lisk的创始人之一Max正面回应过了,具体可以看看这个http://ethereum.stackexch ...
- 剑指Offer面试题:6.用两个栈实现队列
一.题目:用两个栈实现队列 题目:用两个栈实现一个队列.队列的声明如下,请实现它的两个函数appendTail和deleteHead,分别完成在队列尾部插入结点和在队列头部删除结点的功能. 原文是使用 ...
- Hadoop学习笔记—20.网站日志分析项目案例(二)数据清洗
网站日志分析项目案例(一)项目介绍:http://www.cnblogs.com/edisonchou/p/4449082.html 网站日志分析项目案例(二)数据清洗:当前页面 网站日志分析项目案例 ...
- 辛巴学院-Unity-剑英陪你零基础学c#系列(二)顺序
这不是草稿 辛巴学院:正大光明的不务正业. 上一次的教程写出来之后,反馈还是挺多的,有很多都做了修改,也有一些让人崩溃,不得不说上几句.有些人有些很奇怪的地方,你写篇东西,被看了以后不说他感觉怎么 ...
- Spark使用实例
1.介绍 Spark是基于Hadoop的大数据处理框架,相比较MapReduce,Spark对数据的处理是在本地内存中进行,中间数据不需要落地,因此速度有很大的提升.而MapReduce在map阶段和 ...
- C语言-指针
C指针基础知识 C语言中,指针无疑是最令人头疼的.今天无事就来学学C语言的指针,在此留下点笔记,仅供个人参考. 首先要搞懂的是,指针是什么? 指针:是用来存放内存地址的变量. 不管是什么类型的指针,存 ...
- JS原生第六篇 (帅哥)
复习 按钮不可用 disabled = "disabled" || true setTimeout 只执行一次 setInterval 执行很多次 递归调用 ...
- [转]关于typedef的用法总结
不管实在C还是C++代码中,typedef这个词都不少见,当然出现频率较高的还是在C代码中.typedef与#define有些相似,但更多的是不同,特别是在一些复杂的用法上,就完全不同了,看了网上一些 ...
- OpenCASCADE Performance Test
OpenCASCADE Performance Test eryar@163.com Abstract. Use the Draw Test Harness to test the performan ...
- 深入理解DOM事件类型系列第三篇——变动事件
× 目录 [1]删除节点 [2]插入节点 [3]特性节点[4]文本节点 前面的话 变动(mutation)事件能在DOM中的某一部分发生变化时给出提示,这类事件非常有用,但都只能使用DOM2级事件处理 ...