UIButton调整内部的子控件的位置

1.此方法不可以更改

// 注意:在按钮外面改的尺寸,按钮的内部都会覆盖掉
button.titleLabel.frame = CGRectMake(0, 0, 100, 70);
button.imageView.frame = CGRectMake(100, 0, 70, 70);

2.可以通过自定义UIButton,重写布局方法更改

- (instancetype)initWithFrame:(CGRect)frame {
    if (self = [super initWithFrame:frame]) {
        // 文本居中
        self.titleLabel.textAlignment = NSTextAlignmentCenter;
        // 改变图片的内容模式
        self.imageView.contentMode = UIViewContentModeCenter;
    }
    return self;
}
/**
 *  重写两个方法
 */
- (CGRect)titleRectForContentRect:(CGRect)contentRect {
    return CGRectMake(0, 0, 100, 70);
}

- (CGRect)imageRectForContentRect:(CGRect)contentRect {
    return CGRectMake(100, 0, 70, 70);
}
#pragma mark - 方式二
- (void)layoutSubviews {
    [super layoutSubviews];
    // 设置子控件的位置
    self.titleLabel.frame = CGRectMake(0, 0, 100, 70);
    self.imageView.frame = CGRectMake(100, 0, 70, 70);
}
// 设置按钮的内边距
// 1.设置内容(包括图片和文字)
self.button.contentEdgeInsets = UIEdgeInsetsMake(-20, 0, 0, 0);

// 2.设置图片
self.button.imageEdgeInsets = UIEdgeInsetsMake(0, 0, 0, 10);

// 3.设置标题
self.button.titleEdgeInsets = UIEdgeInsetsMake(0, 0, 0, -10);
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,269评论 19 139
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 174,613评论 25 709
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,296评论 4 61
  • 1 星爷可以在电影里解构一切,调侃一切,但男主和女主的爱情却只能一纯到底,不可亵玩。过往的作品皆如是,此乃星爷内心...
    渣山论剑阅读 555评论 0 3
  • 以前觉得姐妹可能是上帝派来和你争抢,让你成长的人;现在我觉得姐妹更像是长在彼此身上的一颗痣,可能会令你难受,让你厌...
    Crystal_南书阅读 159评论 0 0