**
     设置内容距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 内部介绍的更多相关文章

  1. 你真的会用UIButton吗? UIButton详细介绍

    本节知识点: 什么是UIButton UIButton的状态 UIButton的属性设置 UIButton基本使用步骤 UIButton的代码创建与常用属性设置 重写按钮的某个状态属性的 setter ...

  2. UIButton内部子控件自定义布局-“UIEdgeInsets”

    UIButton UIButton做frame动画时,不响应点击 在一个View内部加入几个按钮,然后改变这个view的frame来做动画,但是按钮不响应点击事件. 问题代码 __block CGRe ...

  3. java虚拟机内部介绍

    一.介绍 java 的内存管理和垃圾回收在某种程度是同一个问题来着.对于java程序员来说,在虚拟机自动内存管理机制的帮助下,不在需要为每一个new操作去写配对的delete/free代码,不容易出现 ...

  4. iOS UIButton详细介绍

    昨天,做了项目中的一点,觉得细节还是很重要的.像一个普通的UIButton,给它调试字体格式,大小什么的,确实是蛮耗时间的. 今天打算详细的归纳归纳.. typedef NS_ENUM(NSInteg ...

  5. LoadRunner内部介绍以及常见问题

    Tools Recording Options 接下来我们挨个看一下里面的东东以及区别 General(通常的) Script,不用修改,是脚本的语言,我们一般都是基于 C 语言的 Protocols ...

  6. ios自定义UIButton内部空间Rect

  7. UIButton的文本与图片的布局

    UIButton内部文本和图片的布局是我们日常代码中,不可缺少的部分,按钮默认左边图片右边文本,那要实现左边文本,右边图片,我们该怎么解决呢,上面图片,下面文本又该怎么办呢 其实很简单,今天总结下,目 ...

  8. 5分钟 搞定UIButton的文本与图片的布局

    UIButton内部文本和图片的布局是我们日常代码中,不可缺少的部分,按钮默认左边图片右边文本,那要实现左边文本,右边图片,我们该怎么解决呢,上面图片,下面文本又该怎么办呢 其实很简单,今天总结下,目 ...

  9. iOS阶段学习第27天笔记(UIButton-UIImageView的介绍)

    iOS学习(UI)知识点整理 一.关于UIButton的介绍 1)概念:UIButton 是一种常用的控件,通过点击触发相应的功能 2)UIButton 的几种常用的状态        1.UICon ...

随机推荐

  1. react native之组织组件

    这些组件包括<TabView>,<NavigatorView>和<ListView>,他们实现了手机端最常用的交互和导航.你会发现这些组件在实际的项目中会非常有用. ...

  2. bootstrap插件学习-bootstrap.scrollspy.js

    先看bootstrap.dropdown.js的结构 function ScrollSpy(){} //构造函数 ScrollSpy.prototype = {} //构造器的原型 $.fn.scro ...

  3. Vue基础---->VueJS的使用(二)

    组件(Component)是 Vue.js 最强大的功能之一.组件可以扩展 HTML 元素,封装可重用的代码.在较高层面上,组件是自定义元素,Vue.js 的编译器为它添加特殊功能.今天我们就来学习一 ...

  4. js关于对象键值为数字型时输出的对象自动排序问题的解决方法

    一.对象键值为数字型时输出的对象自动排序问题如: var objs = {    "1603":{id:"1603"},    "1702" ...

  5. 【Win10】让 AppBarButton 支持更复杂的 Icon 内容

    最近有一个需求,需要制作这么一个 AppBarButton: 这个 AppBarButton 的 Icon 是一个评论框图标里面再显示评论数(大于 99 条则显示 99+).其中评论数是通过数据绑定得 ...

  6. 重构第24天 分解复杂的判断(Remove Arrowhead Antipattern)

    理解: 当你的代码中有很深的嵌套条件时,花括号就会在代码中形成一个长长的箭头.我们经常在不同的代码中看到这种情况,并且这种情况也会扰乱代码的可读性. 如下代码所示,HasAccess方法里面包含一些嵌 ...

  7. 加密–RSA前端与后台的加密&解密

    1. 前言 本问是根据网上很多文章的总结得到的. 2. 介绍 RSA加密算法是一种非对称加密算法. 对极大整数做因数分解的难度决定了RSA算法的可靠性.换言之,对一极大整数做因数分解愈困难,RSA算法 ...

  8. 【状态模式】 State Pattern

    我们先设计一个场景,饮料自动售卖机,来设计一下它的出售流程. 流程图中,我们可把这个过程看成几个状态: 投币状态,选择饮料状态,售出状态,出售完毕状态. ,有了这个四个状态,我们设计一下界面(很粗略) ...

  9. 用Perl编写Apache模块

    前言 Apache被许多大流量网站所嫌弃,但很多企业级的场景则更为适用. Apache httpd 从 2.0 之后,已经不仅仅局限于一个 http 的服务器,更是一个完善而强大.灵活而健壮且容易扩展 ...

  10. unity3d拓展编辑器Editor的使用

    Editor可以拓展Inspector窗口 可以通过代码自己绘制监测面板 先来看一个效果: