UIButton 内部介绍
**
设置内容距btn边框距离
**/
btn.contentEdgeInsets = UIEdgeInsetsMake(0, 0, 0, 0);
/** 将label和imageView看成一个整体
比如将imageview放到label后面 则需要计算 imageview与label相对的位置 和距离另外一个边的距离
通俗的说 默认情况下的 imageview在左 titlelabel在右
imageEdgeInsets left对比位置未 按钮左边框 right 对比与他相邻的label
titlelabelEdgeInsets 与 image相同
下面代码为 左右交换image与label
**/
[btn setImageEdgeInsets:UIEdgeInsetsMake(0,btn.titleLabel.frame.size.width, 0,-btn.titleLabel.frame.size.width-btn.imageView.frame.size.width)];
[btn setTitleEdgeInsets:UIEdgeInsetsMake(0, 0, 0,CGRectGetWidth(btn.imageView.frame))];
这个方法计算起来比较麻烦 不如直接自定义button 来 重写layoutSubviews方法 直接设置 image lable frame 来达到效果
注:[super layoutSubviews]
/**
reversesTitleShadowWhenHighlighted 设置标题高亮时 阴影是否突出显示
adjustsImageWhenHighlighted 默认是肯定的。如果是的话,图像被高亮显示时(按下)
adjustsImageWhenDisabled 默认是肯定的。如果是,图像被禁用时禁用
showsTouchWhenHighlighted 默认情况下是没有。如果是,显示一个简单的反馈(目前为辉光),而高亮显示
**/
btn.reversesTitleShadowWhenHighlighted = NO;
btn.showsTouchWhenHighlighted = YES;
//设置阴影颜色
[btn setTitleShadowColor:[UIColor redColor] forState:UIControlStateNormal];
[btn setTitleShadowColor:[UIColor greenColor] forState:UIControlStateHighlighted];
//attributedString标题设置
NSMutableDictionary * dic = [[NSMutableDictionary alloc]init];
[dic setObject:[UIColor redColor] forKey:NSBackgroundColorAttributeName];
NSAttributedString * aStr = [[NSAttributedString alloc]initWithString:@"33333" attributes:dic];
[btn setAttributedTitle:aStr forState:UIControlStateNormal];
/**
获取相应状态的属性值
- (nullable UIColor *)titleColorForState:(UIControlState)state
- (nullable UIColor *)titleShadowColorForState:(UIControlState)state
- (nullable UIImage *)imageForState:(UIControlState)state
- (nullable UIImage *)backgroundImageForState:(UIControlState)state
- (nullable NSAttributedString *)attributedTitleForState:(UIControlState)state
**/
/*
在子类化的时候你可以重载下面这些方法,这些方法返回CGRect结构,指明了按钮每一组成部分的边界。
注意:不要直接调用这些方法, 这些方法是你写给系统调用的。
- (CGRect)backgroundRectForBounds:(CGRect)bounds 制定背景边框
- (CGRect)contentRectForBounds:(CGRect)bounds 制定内容边界
- (CGRect)titleRectForContentRect:(CGRect)contentRect 文字标题边界
- (CGRect)imageRectForContentRect:(CGRect)contentRect 按钮图像边界
*/
UIButton 内部介绍的更多相关文章
- 你真的会用UIButton吗? UIButton详细介绍
本节知识点: 什么是UIButton UIButton的状态 UIButton的属性设置 UIButton基本使用步骤 UIButton的代码创建与常用属性设置 重写按钮的某个状态属性的 setter ...
- UIButton内部子控件自定义布局-“UIEdgeInsets”
UIButton UIButton做frame动画时,不响应点击 在一个View内部加入几个按钮,然后改变这个view的frame来做动画,但是按钮不响应点击事件. 问题代码 __block CGRe ...
- java虚拟机内部介绍
一.介绍 java 的内存管理和垃圾回收在某种程度是同一个问题来着.对于java程序员来说,在虚拟机自动内存管理机制的帮助下,不在需要为每一个new操作去写配对的delete/free代码,不容易出现 ...
- iOS UIButton详细介绍
昨天,做了项目中的一点,觉得细节还是很重要的.像一个普通的UIButton,给它调试字体格式,大小什么的,确实是蛮耗时间的. 今天打算详细的归纳归纳.. typedef NS_ENUM(NSInteg ...
- LoadRunner内部介绍以及常见问题
Tools Recording Options 接下来我们挨个看一下里面的东东以及区别 General(通常的) Script,不用修改,是脚本的语言,我们一般都是基于 C 语言的 Protocols ...
- ios自定义UIButton内部空间Rect
- UIButton的文本与图片的布局
UIButton内部文本和图片的布局是我们日常代码中,不可缺少的部分,按钮默认左边图片右边文本,那要实现左边文本,右边图片,我们该怎么解决呢,上面图片,下面文本又该怎么办呢 其实很简单,今天总结下,目 ...
- 5分钟 搞定UIButton的文本与图片的布局
UIButton内部文本和图片的布局是我们日常代码中,不可缺少的部分,按钮默认左边图片右边文本,那要实现左边文本,右边图片,我们该怎么解决呢,上面图片,下面文本又该怎么办呢 其实很简单,今天总结下,目 ...
- iOS阶段学习第27天笔记(UIButton-UIImageView的介绍)
iOS学习(UI)知识点整理 一.关于UIButton的介绍 1)概念:UIButton 是一种常用的控件,通过点击触发相应的功能 2)UIButton 的几种常用的状态 1.UICon ...
随机推荐
- 移动WEB开发中媒体查询里的width, device-width, resolution
/*1.width: viewport的宽度,css像素,三星S3的viewort默认宽度是980px. 当设置viewport width=device-width时,对应的媒体查询中width的值 ...
- C中调用Lua函数
我们先来看一个简单的例子: lua_State* L = NULL; // 内部调用lua函数 double f(double x, double y) { double z; lua_getglob ...
- 看那记不住命令的猿,如何使用GitHub
什么是GitHub呢? GitHub是什么?好吧, 请看百科:http://baike.baidu.com/view/3366456.htm 准备:msysgit.tortoisegit 首先,我们得 ...
- 2 Servlet基础
作者:禅楼望月(http://www.cnblogs.com/yaoyinglong) 1. 从浏览器访问Servlet的流程 刚才发现,这里的图片不能正常显示,所以我给个链接,大家可以下载下来看从浏 ...
- EPANET头文件解读系列9——VARS.H
/************************************************************************* Global Variabl ...
- Mysql创建用户的三种基本方法
1.采用create user e.g. create user 'username'@'host' identified by 'password'; 2.采用grant语句 e.g. gran ...
- sprint3冲刺团队贡献分-软件工程
蔡舜 : 20 卢晓洵 : 19 林宇粲 :22 王昕明 :21
- Sprint回顾
1.回顾组织 主题:“我们下次怎么样才能更加认真对待?” 时间:设定为1至2个小时. 参与者:整个团队. 场所:能够在不受干扰的情况下讨论. 秘书:指定某人当秘书,筹备.记录.整理. 2.回顾流程 ...
- 译:泛型List集合转化为DateTable的扩展方法
译文出处:http://www.codeproject.com/Tips/867866/Extension-Method-for-Generic-List-Collection-to-Da 这段代码是 ...
- Winform开发框架主界面设计展示
做了好多年Winform的程序的开发,主窗口的界面设计一般都要求做的更好一些,可以根据不同的系统功能模块进行归类整合,能使客户迅速寻找到相关功能的同时,也能感觉到整体性的美观大方,因此主窗口的界面设计 ...