当前位置: 移动技术网 > IT编程>移动开发>IOS > 详解iOS中UIButton的三大UIEdgeInsets属性用法

详解iOS中UIButton的三大UIEdgeInsets属性用法

2019年07月24日  | 移动技术网IT编程  | 我要评论

江润黎,贵州人事人才信息网,色臀

uiedgeinsets是什么

uiedgeinsets是什么?我们点进去看一下:

typedef struct uiedgeinsets {
  cgfloat top, left, bottom, right; // specify amount to inset (positive) for each of the edges. values can be negative to 'outset'
} uiedgeinsets;

uiedgeinsets是个结构体类型。里面有四个参数,分别是:top, left, bottom, right。这四个参数表示距离上边界、左边界、下边界、右边界的距离。

哪三个uiedgeinsets属性

不知道大家发现没有,uibutton里面有三个uiedgeinsets属性,分别是:

@property(nonatomic)     uiedgeinsets contentedgeinsets ui_appearance_selector; // default is uiedgeinsetszero

@property(nonatomic)     uiedgeinsets titleedgeinsets;        // default is uiedgeinsetszero

@property(nonatomic)     uiedgeinsets imageedgeinsets;        // default is uiedgeinsetszero

contentedgeinsets后面有个ui_appearance_selector是什么意思呢?

提示:ui_appearance_selector标记的属性都支持通过外观代理来定制。
举例,设置uibutton的contentedgeinsets属性,可以直接调用:

[[uibutton appearance] settitleedgeinsets:uiedgeinsetsmake(0, 0, 0, 0)];

创建uibutton:

uibutton *button = [[uibutton alloc] init];
button.frame = cgrectmake(50, 200, 200, 50);
[button settitle:@"我是uibutton" forstate:uicontrolstatenormal];
[button settitlecolor:[uicolor bluecolor] forstate:uicontrolstatenormal];
[button setbackgroundcolor:[uicolor orangecolor]];
button.titlelabel.textalignment = nstextalignmentleft;
button.contenthorizontalalignment = uicontrolcontenthorizontalalignmentleft;
[self.view addsubview:button];

创建一个button,让button的title居左,以便观察:

2016425143210943.png (146×97)

uibutton的contentedgeinsets属性

@property(nonatomic)     uiedgeinsets contentedgeinsets ui_appearance_selector; 

// default is uiedgeinsetszero

contentedgeinsets里有一个content应该指的就是uibutton的title。

参数含义:

上面我们讲了uiedgeinsets是个结构体类型。里面有四个参数,分别是:top, left, bottom, right。这四个参数表示距离上边界、左边界、下边界、右边界的距离。

这四个参数的值可以为正值,也可以为负值。拿left举例:

left = 10; //代表以当前位置为基准,向右移动10个像素
left = -10; //代表以当前位置为基准,向左移动10个像素

向右移动20个像素

button.contentedgeinsets = uiedgeinsetsmake(0, 20, 0, 0);

向右移动20个像素,left = 20,就可以了。

2016425143256442.png (154×80)

向左移动20个像素

button.contentedgeinsets = uiedgeinsetsmake(0, -20, 0, 0);

2016425143338999.png (146×80)

uibutton的titleedgeinsets属性

titleedgeinsets和contentedgeinsets的作用差不多。我们及设置contentedgeinsets,又设置titleedgeinsets,会怎样呢?

button.titleedgeinsets = uiedgeinsetsmake(0, 20, 0, 0);
button.contentedgeinsets = uiedgeinsetsmake(0, 20 , 0, 0);

看一下效果:

2016425143400935.png (152×97)

uibutton的imageedgeinsets属性

创建一个带照片的button:

uibutton *button = [[uibutton alloc] init];
button.frame = cgrectmake(50, 200, 200, 200);
[button settitlecolor:[uicolor bluecolor] forstate:uicontrolstatenormal];
[button setbackgroundcolor:[uicolor orangecolor]];
[button setimage:[uiimage imagenamed:@"test"] forstate:uicontrolstatenormal];
[self.view addsubview:button];

运行一下:

2016425143505909.png (169×161)

向右移动50个像素

button.imageedgeinsets = uiedgeinsetsmake(0, 50, 0, 0);

看看效果:

2016425143526865.png (170×190)

向左移动50个像素

button.imageedgeinsets = uiedgeinsetsmake(0, -50, 0, 0);

看看效果:

2016425143547866.png (181×178)

大家可以自行设置其他三个参数看看效果是怎样的,自己动手便于理解。

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

  • ios uicollectionview实现横向滚动

    现在使用卡片效果的app很多,之前公司让实现一种卡片效果,就写了一篇关于实现卡片的文章。文章最后附有demo实现上我选择了使用uicollectionview ... [阅读全文]
  • iOS UICollectionView实现横向滑动

    本文实例为大家分享了ios uicollectionview实现横向滑动的具体代码,供大家参考,具体内容如下uicollectionview的横向滚动,目前我使... [阅读全文]
  • iOS13适配深色模式(Dark Mode)的实现

    iOS13适配深色模式(Dark Mode)的实现

    好像大概也许是一年前, mac os系统发布了深色模式外观, 看着挺刺激, 时至今日用着也还挺爽的终于, 随着iphone11等新手机的发售, ios 13系统... [阅读全文]
  • ios 使用xcode11 新建项目工程的步骤详解

    ios 使用xcode11 新建项目工程的步骤详解

    xcode11新建项目工程,新增了scenedelegate这个类,转而将原appdelegate负责的对ui生命周期的处理担子接了过来。故此可以理解为:ios... [阅读全文]
  • iOS实现转盘效果

    本文实例为大家分享了ios实现转盘效果的具体代码,供大家参考,具体内容如下demo下载地址: ios转盘效果功能:实现了常用的ios转盘效果,轮盘抽奖效果的实现... [阅读全文]
  • iOS开发实现转盘功能

    本文实例为大家分享了ios实现转盘功能的具体代码,供大家参考,具体内容如下今天给同学们讲解一下一个转盘选号的功能,直接上代码直接看viewcontroller#... [阅读全文]
  • iOS实现轮盘动态效果

    本文实例为大家分享了ios实现轮盘动态效果的具体代码,供大家参考,具体内容如下一个常用的绘图,主要用来打分之类的动画,效果如下。主要是ios的绘图和动画,本来想... [阅读全文]
  • iOS实现九宫格连线手势解锁

    本文实例为大家分享了ios实现九宫格连线手势解锁的具体代码,供大家参考,具体内容如下demo下载地址:效果图:核心代码://// clockview.m// 手... [阅读全文]
  • iOS实现卡片堆叠效果

    本文实例为大家分享了ios实现卡片堆叠效果的具体代码,供大家参考,具体内容如下如图,这就是最终效果。去年安卓5.0发布的时候,当我看到安卓全新的material... [阅读全文]
  • iOS利用余弦函数实现卡片浏览工具

    iOS利用余弦函数实现卡片浏览工具

    本文实例为大家分享了ios利用余弦函数实现卡片浏览工具的具体代码,供大家参考,具体内容如下一、实现效果通过拖拽屏幕实现卡片移动,左右两侧的卡片随着拖动变小,中间... [阅读全文]
验证码:
移动技术网