自定义UIButton

开发中总是遇到创建个人信息和添加活动的页面,用tableview时取值判断感觉麻烦,手搭又感觉费劲,就偷懒自定义了下button,也算是简单的用法,不知道值不值得推荐,反正个人感觉在这里还是挺方便的,贴出来还望大家多多指教

.h

#import <UIKit/UIKit.h>

@interface AddActivityButton : UIButton
@property (copy, nonatomic)NSString *detail;
@end

.m

#import "AddActivityButton.h"

@interface AddActivityButton()
{
    UILabel *_detailLabel;
}
@end
@implementation AddActivityButton

- (instancetype)init
{
    self = [super init];
    if (self) {
        @throw [NSException exceptionWithName:@"AddActivityButton Exception" reason:@"must use method:initWithFrame:" userInfo:nil];
    }
    return self;
}

- (instancetype)initWithFrame:(CGRect)frame
{
    self = [super initWithFrame:frame];
    if (self) {
        self.titleLabel.textAlignment = NSTextAlignmentLeft;
        self.titleLabel.textColor = [UIColor grayColor];
        _detailLabel = [RMUtils labelWith:CGRectMake(self.width/2, 5, self.width/2 - 30, frame.size.height - 10) font:[RMUtils defaultFont] text:_detail textColor:[UIColor grayColor]];
        _detailLabel.textAlignment = NSTextAlignmentRight;
        [self addSubview:_detailLabel];
    }
    return self;
}

- (void)setDetail:(NSString *)detail
{
    _detailLabel.text = detail;
}

- (CGRect)titleRectForContentRect:(CGRect)contentRect
{
    CGFloat x = 5;
    CGFloat y = 5;
    CGFloat width = contentRect.size.width/2 - 10;
    CGFloat height = contentRect.size.height - 10;
    return CGRectMake(x, y, width, height);
}

- (CGRect)imageRectForContentRect:(CGRect)contentRect
{
    CGFloat x = self.width- 25;
    CGFloat y = 15;
    CGFloat width = 10;
    CGFloat height = 10;
    return CGRectMake(x, y, width, height);
}

创建后的button图



textfield,textview这些控件也有这些方法,都可以进行自定义,比如说想在textfield和textview的前面流出空格加个,改变frame了,都可以继承父类实现方法,




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值