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 ...
随机推荐
- 自定义一个叫 ReadOnlyXmlMembershipProvider 的 MembershipProvider,用 XML 作为用户储藏室
1. 配置 web.config <membership defaultProvider="AspNetReadOnlyXmlMembershipProvider"> ...
- WebStorm 8 注册码
UserName:William ===== LICENSE BEGIN ===== 45550-12042010 00001SzFN0n1bPII7FnAxnt0DDOPJA INauvJkeVJB ...
- STL中vector小结
()使用vector之前必须包含头文件<vector>:#include<vector> ()namespace std{ template <class T, clas ...
- 【解决方案】HTTP could not register URL http://+:6001/
Failed to host the DeployerNotificationReceiverSystem.ServiceModel.AddressAccessDeniedException: HTT ...
- Flow: JavaScript静态类型检查工具
Flow: JavaScript静态类型检查工具 Flow是Facebook出品的,针对JavaScript的静态类型检查工具.其代码托管在github之上,并遵守BSD开源协议. 关于Flow 它可 ...
- Mysql 修改密码及重置密码方法
修改密码: //选择数据库 use mysql; //修改密码 update user set password=password('新密码') where user='root'; //立即生效 f ...
- CSS3魔法堂:禁止用户改变textarea大小
一.前言 在FF.Chrome和Safari下默认时允许用户以拖拽形式来改变textarea大小,这不仅与IE下textarea的行为特点有异,而且textarea的大小变化会撑大其父节点从而破坏整体 ...
- jquery选择器(原创)
jquery选择器大方向可以分为这样: 下面我们先来看看基本选择器总的CSS选择器: 1.标签选择器: $("element") 其中,参数element,表示待查找的HTML标记 ...
- 可拖动FPS显示框(UGUI)
简介 本来是想往上找一个可拖动FPS显示框的(我记得以前有人写过),然而搜了一个多小时都没搜到,索性自己写了一个,花费不到20分钟,看来还是自己动手丰衣足食啊 o(╯□╰)o 效果 上下的Toast不 ...
- java 接口学习
你应该知道接口是一种契约,它与实现方式无关 但是类,即使是抽象类,你都能自定义成员变量,而成员变量往往就与实现方式有关. 这一点的实际意义不大. 但是有一点,类会暴露太多不必要,甚至不能暴露的东西,你 ...