UIButton中的**EdgeInsets是做什么用的?-阿里云开发者社区

开发者社区> 云计算> 正文
登录阅读全文

UIButton中的**EdgeInsets是做什么用的?

简介:

UIButton中的**EdgeInsets是做什么用的?

 

UIEdgeInsetsMake

Creates an edge inset for a button or view.
An inset is a margin around the drawing rectangle where each side (left, right, top, and bottom) can have a different value.

给一个button或者view创建一个嵌入的边缘.

inset是一个矩形view页边空白,每一边都可以设定一个不同的值.

 

图片素材: 1@2x.png


- (void)viewDidLoad
{
    [super viewDidLoad];

    UIButton *normalButton = nil;
    UIButton *edgeButton   = nil;
    
    // normalButton
    {
        // 初始化按钮
        normalButton = [[UIButton alloc] initWithFrame:CGRectMake(100, 100, 100, 100)];
        normalButton.backgroundColor = [UIColor blackColor];
        
        // 按钮图片
        [normalButton setImage:[UIImage imageNamed:@"1"] forState:UIControlStateNormal];
    }
    
    // EdgeButton
    {
        // 初始化按钮
        edgeButton = [[UIButton alloc] initWithFrame:CGRectMake(100, 210, 100, 100)];
        edgeButton.backgroundColor = [UIColor blackColor];
        
        // 按钮图片
        [edgeButton setImage:[UIImage imageNamed:@"1"] forState:UIControlStateNormal];
        
        // 设置图片间距
        edgeButton.imageEdgeInsets = UIEdgeInsetsMake(10, 10, 10, 10);
    }
    
    [self.view addSubview:normalButton];
    [self.view addSubview:edgeButton];
}

viewDidLoad

以下是模拟器显示结果:

从结果中可以看到,设置了图片的imageEdgeInsets后,图片显示被缩放了哦.

 

再来测试文本的titleEdgeInsets

- (void)viewDidLoad
{
    [super viewDidLoad];

    UIButton *normalButton = nil;
    UIButton *edgeButton   = nil;
    
    // normalButton
    {
        // 初始化按钮
        normalButton = [[UIButton alloc] initWithFrame:CGRectMake(100, 100, 100, 100)];
        normalButton.backgroundColor = [UIColor blackColor];
        
        [normalButton setTitle:@"Y.X." forState:UIControlStateNormal];
        [normalButton setTitleColor:[UIColor redColor] forState:UIControlStateNormal];
    }
    
    // EdgeButton
    {
        // 初始化按钮
        edgeButton = [[UIButton alloc] initWithFrame:CGRectMake(100, 210, 100, 100)];
        edgeButton.backgroundColor = [UIColor blackColor];
        
        [edgeButton setTitle:@"Y.X." forState:UIControlStateNormal];
        [edgeButton setTitleColor:[UIColor redColor] forState:UIControlStateNormal];
        
        edgeButton.titleEdgeInsets = UIEdgeInsetsMake(60, 60, 0, 0);
    }
    
    [self.view addSubview:normalButton];
    [self.view addSubview:edgeButton];
}

viewDidLoad

以下是运行结果:

文本并没有缩放的说,再试试这么设置:

UIButton还有一个属性叫contentEdgeInsets.

Use this property to resize and reposition the effective drawing rectangle for the button content. The content comprises the button image and button title.

实际上,这个contentEdgeInsets是用来同时设置imageEdgeInsets与titleEdgeInsets的,没什么特别的,就不举例子了:)

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

分享: