ios 巧用UIButton的UIControlStateSelected属性

一般可以巧用UIBUtton的UIControlStateSelected属性,来设置UIButton的选中背景图片。

- (UIButton *)normalButton
{
    if (!_normalButton)
    {
        UIImage *_ljImage = [UIImage imageNamed:@"lj_unselect.png"];
        _normalButton = [[UIButton alloc] initWithFrame:CGRectMake(kDEVICEWIDTH/2 - 80 - 40, 81 - 15, 50, 50)];
        //_normalButton.backgroundColor = [UIColor redColor];
        _normalButton.tag = 1000;
        [_normalButton setImage:[UIImage imageNamed:@"lj_unselect.png"] forState:UIControlStateNormal];
        [_normalButton setImage:[UIImage imageNamed:@"lj_select.png"] forState:UIControlStateSelected];
        [_normalButton addTarget:self action:@selector(buttonClick:) forControlEvents:UIControlEventTouchUpInside];
        [_normalButton setSelected:YES]; //默认选中状态
    }
    return _normalButton;
}

- (UIButton *)bigButton
{
    if (!_bigButton)
    {
        UIImage *_ljImage = [UIImage imageNamed:@"lj_unselect.png"];
        _bigButton = [[UIButton alloc] initWithFrame:CGRectMake(kDEVICEWIDTH/2 + 42 -10, 81 - 15, 50, 50)];
        //_bigButton.backgroundColor = [UIColor redColor];
        _bigButton.tag = 2000;
        [_bigButton setImage:[UIImage imageNamed:@"lj_unselect.png"] forState:UIControlStateNormal];
        [_bigButton setImage:[UIImage imageNamed:@"lj_select.png"] forState:UIControlStateSelected];
        [_bigButton addTarget:self action:@selector(buttonClick:) forControlEvents:UIControlEventTouchUpInside];
    }
    return _bigButton;
}

/*
 字体选中按钮点击
 */
- (void)buttonClick:(UIButton *)sender
{
    sender.selected = !sender.selected;//状态取反
    if (sender.tag == 1000) //标准
    {
        [_bigButton setSelected:NO];
    }
    else if (sender.tag == 2000)//大
    {
        [_normalButton setSelected:NO];
    }
}


效果图:



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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值