UIButton的selected状态

设置button的selected状态下image和title的时候,要注意,本身对按钮的点击是不会改变selected状态的,需要我们在按钮的监听方法里去对这个值设置,才会触发到不同状态下

下面代码是通过button做的一个简易的复选框

#import "ViewController.h"


@interface ViewController ()


@end


@implementation ViewController

- (void)loadView{

    self.view = [[UIView alloc]initWithFrame:[[UIScreen mainScreen]bounds]];

    UIButton *button = [UIButton buttonWithType:UIButtonTypeCustom];

    [button setFrame:CGRectMake((self.view.bounds.size.width-180)/2, (self.view.bounds.size.height-44)/2, 180, 44)];

    //normal

    [button setImage:[UIImage imageNamed:[NSString stringWithFormat:@"login_checkbox_normal.png"]] forState:UIControlStateNormal];

    [button setTitle:@"点我啊" forState:UIControlStateNormal];

    [button setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];

    [button.titleLabel setFont:[UIFont systemFontOfSize:17]];


    [button addTarget:self action:@selector(tapButton:) forControlEvents:UIControlEventTouchUpInside];

    [self.view addSubview:button];

}

- (void)viewDidLoad {

    [super viewDidLoad];

}


- (void)didReceiveMemoryWarning {

    [super didReceiveMemoryWarning];

}

#pragma mark - 按钮点击事件

- (void)tapButton:(UIButton *)button{

    [button setSelected:!button.isSelected];

    if (button.isSelected) {

         //selected

        [button setImage:[UIImage imageNamed:[NSString stringWithFormat:@"login_checkbox_checked.png"]] forState:UIControlStateSelected];

        [button setTitle:@"卧槽你真点" forState:UIControlStateSelected];

        [button setTitleColor:[UIColor blackColor] forState:UIControlStateSelected];

        [button.titleLabel setFont:[UIFont systemFontOfSize:17]];


    }else{

        //normal

        [button setImage:[UIImage imageNamed:[NSString stringWithFormat:@"login_checkbox_normal.png"]] forState:UIControlStateNormal];

        [button setTitle:@"点我啊" forState:UIControlStateNormal];

        [button setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];

        [button.titleLabel setFont:[UIFont systemFontOfSize:17]];


    }

}

@end



  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值