定制二选一按钮SwitchButton
定制二选一按钮SwitchButton

效果:

源码:
SwitchButton.h 与 SwitchButton.m
//
// SwitchButton.h
// KongJian
//
// Created by YouXianMing on 14/10/24.
// Copyright (c) 2014年 YouXianMing. All rights reserved.
// #import <UIKit/UIKit.h> @protocol SwitchButtonDelegate <NSObject>
- (void)switchButtonState:(BOOL)state;
@end @interface SwitchButton : UIView /**
* 代理
*/
@property (nonatomic, assign) id<SwitchButtonDelegate> delegate; /**
* 3个view
*/
@property (nonatomic, strong) UIView *leftView;
@property (nonatomic, strong) UIView *rightView;
@property (nonatomic, strong) UIView *blockView; /**
* 动画持续时间
*/
@property (nonatomic, assign) NSTimeInterval duration; /**
* 块是否在左边
*/
@property (nonatomic, assign) BOOL blockAtLeft; /**
* 背景颜色
*/
@property (nonatomic, strong) UIColor *leftBackgroundColor;
@property (nonatomic, strong) UIColor *rightBackgroundColor; /**
* 便利的创建出按钮
*
* @param leftText 左边显示的文本
* @param rightText 右边显示的文本
* @param size button的尺寸
*
* @return button对象
*/
+ (SwitchButton *)createDefaultTypeButtonWithLeftText:(NSString *)leftText
rightText:(NSString *)rightText
size:(CGSize)size; @end
//
// SwitchButton.m
// KongJian
//
// Created by YouXianMing on 14/10/24.
// Copyright (c) 2014年 YouXianMing. All rights reserved.
// #import "SwitchButton.h" @interface SwitchButton () @property (nonatomic, strong) UIButton *button; @property (nonatomic, strong) UIView *leftBackView;
@property (nonatomic, strong) UIView *rightBackView;
@property (nonatomic, strong) UIView *blockBackView; @end @implementation SwitchButton - (instancetype)initWithFrame:(CGRect)frame
{
self = [super initWithFrame:frame];
if (self) {
self.layer.masksToBounds = YES; // 按钮
_button = [[UIButton alloc] initWithFrame:self.bounds];
[_button addTarget:self
action:@selector(buttonEvent)
forControlEvents:UIControlEventTouchUpInside];
[self addSubview:_button]; // 左侧view
_leftBackView = [[UIView alloc] initWithFrame:CGRectMake(, ,
self.bounds.size.width / .f,
self.bounds.size.height)];
_leftBackView.userInteractionEnabled = NO;
[self addSubview:_leftBackView]; // 右侧view
_rightBackView = [[UIView alloc] initWithFrame:CGRectMake(self.bounds.size.width / .f, ,
self.bounds.size.width / .f, self.bounds.size.height)];
_rightBackView.userInteractionEnabled = NO;
[self addSubview:_rightBackView]; // 遮挡用的view
_blockBackView = [[UIView alloc] initWithFrame:CGRectMake(, ,
self.bounds.size.width / .f,
self.bounds.size.height)];
_blockBackView.userInteractionEnabled = NO;
[self addSubview:_blockBackView]; }
return self;
} - (void)buttonEvent {
if (_blockBackView.frame.origin.x == ) {
if (_delegate) {
[_delegate switchButtonState:YES];
} [UIView animateWithDuration:(_duration > ? _duration : 0.2f)
animations:^{
_blockBackView.frame = CGRectMake(self.bounds.size.width / .f, ,
self.bounds.size.width / .f, self.bounds.size.height);
if (_leftBackgroundColor) {
_button.backgroundColor = _leftBackgroundColor;
} } completion:^(BOOL finished) { }];
} else {
[_delegate switchButtonState:NO];
[UIView animateWithDuration:(_duration > ? _duration : 0.2f)
animations:^{
_blockBackView.frame = CGRectMake(, ,
self.bounds.size.width / .f, self.bounds.size.height);
if (_rightBackgroundColor) {
_button.backgroundColor = _rightBackgroundColor;
}
} completion:^(BOOL finished) { }];
}
} @synthesize leftView = _leftView;
- (void)setLeftView:(UIView *)leftView {
_leftView = leftView;
leftView.userInteractionEnabled = NO;
[_leftBackView addSubview:leftView]; [self bringSubviewToFront:_blockBackView];
} @synthesize rightView = _rightView;
- (void)setRightView:(UIView *)rightView {
_rightView = rightView;
rightView.userInteractionEnabled = NO;
[_rightBackView addSubview:rightView]; [self bringSubviewToFront:_blockBackView];
} @synthesize blockView = _blockView;
- (void)setBlockView:(UIView *)blockView {
_blockView = blockView;
blockView.userInteractionEnabled = NO;
[_blockBackView addSubview:blockView]; [self bringSubviewToFront:_blockBackView];
} @synthesize blockAtLeft = _blockAtLeft;
- (void)setBlockAtLeft:(BOOL)blockAtLeft {
_blockAtLeft = blockAtLeft;
if (blockAtLeft == YES) {
_blockBackView.frame = CGRectMake(, ,
self.bounds.size.width / .f,
self.bounds.size.height);
} else {
_blockBackView.frame = CGRectMake(self.bounds.size.width / .f, ,
self.bounds.size.width / .f, self.bounds.size.height);
}
} #pragma mark - 便利构造器
+ (SwitchButton *)createDefaultTypeButtonWithLeftText:(NSString *)leftText
rightText:(NSString *)rightText
size:(CGSize)size {
SwitchButton *button = [[SwitchButton alloc] initWithFrame:CGRectMake(, , size.width, size.height)];
button.layer.cornerRadius = .f;
button.blockAtLeft = NO;
button.leftBackgroundColor = [UIColor colorWithRed:0.969 green:0.365 blue:0.137 alpha:];
button.backgroundColor = [UIColor colorWithRed:0.969 green:0.365 blue:0.137 alpha:];
button.rightBackgroundColor = [UIColor colorWithRed:0.278 green:0.835 blue:0.855 alpha:]; button.duration = 0.3f; // 左侧文本
UILabel *man = [[UILabel alloc] initWithFrame:CGRectMake(, , button.bounds.size.width/.f,
button.bounds.size.height)];
man.text = leftText;
man.textColor = [UIColor whiteColor];
man.font = [UIFont systemFontOfSize:.f];
man.textAlignment = NSTextAlignmentCenter;
button.leftView = man; // 右侧文本
UILabel *woman = [[UILabel alloc] initWithFrame:CGRectMake(, , button.bounds.size.width/.f,
button.bounds.size.height)];
woman.text = rightText;
woman.textColor = [UIColor whiteColor];
woman.font = [UIFont systemFontOfSize:.f];
woman.textAlignment = NSTextAlignmentCenter;
button.rightView = woman; // 中间挡住的块
UIView *blockView = [[UIView alloc] initWithFrame:CGRectMake(, , button.bounds.size.width/.f - ,
button.bounds.size.height - )];
blockView.layer.cornerRadius = .f;
blockView.backgroundColor = [UIColor whiteColor];
button.blockView = blockView; return button;
} @end
使用时候源码:
//
// ViewController.m
// KongJian
//
// Created by YouXianMing on 14/10/24.
// Copyright (c) 2014年 YouXianMing. All rights reserved.
// #import "ViewController.h"
#import "SwitchButton.h" @interface ViewController ()<SwitchButtonDelegate> @end @implementation ViewController - (void)viewDidLoad {
[super viewDidLoad]; SwitchButton *button = [SwitchButton createDefaultTypeButtonWithLeftText:@"Y"
rightText:@"X"
size:CGSizeMake(, )];
button.delegate = self;
button.center = self.view.center;
[self.view addSubview:button];
} - (void)switchButtonState:(BOOL)state {
NSLog(@"%d", state);
} @end
核心的地方:

便利构造器(你可以自己去写):

定制二选一按钮SwitchButton的更多相关文章
- 设计多选一按钮ChooseOnlyButton
设计多选一按钮ChooseOnlyButton 效果: 源码: ChooseOnlyButton.h 与 ChooseOnlyButton.m // // ChooseOnlyButton.h // ...
- sencha touch Model validations 自定义验证 二选一输入验证、重复验证、时间验证、比较验证、条件验证(2015-1-14)
项目初始化时执行以下代码 //重写模型,方便进行自定义验证 Ext.define("Ext.zh.data.Model", { override: "Ext.data.M ...
- 设计可以多选的按钮ChooseManyButton
设计可以多选的按钮ChooseManyButton 效果: 源码: ChooseManyButton.h 与 ChooseManyButton.m // // ChooseManyButton.h / ...
- 定制选择范围的按钮RangeButton
定制选择范围的按钮RangeButton 效果: 源码: RangeButton.h 与 RangeButton.m // // RangeButton.h // PulsingView // // ...
- Android笔记-5-EditText密码和Checkbox二选一
EditText密码:明文和密文 密文: public class MainActivity extends Activity { private EditText password = null; ...
- jquery validate 二选一,错误提示在一处
转载自:http://blog.51yip.com/jsjquery/1483.html 有一同事对jquery validate这个插件不熟,实现多处报错信息在一处,并且还有二选一的情况,二个输入框 ...
- 三大视频网站Url的处理保存(视频和图片二选一操作)
前台Js // 视频处理 var textVideoLink=$("input[name='textVideoLink']").val(); // 去除所有有的引号和空格 var ...
- JS流程控制语句 二选一 (if...else语句) 语法: if(条件) { 条件成立时执行的代码} else {条件不成立时执行的代码}
二选一 (if...else语句) if...else语句是在指定的条件成立时执行代码,在条件不成立时执行else后的代码. 语法: if(条件) { 条件成立时执行的代码} else {条件不成立时 ...
- html弹出二选一窗口,然后根据点击执行对应的js方法
html弹出二选一窗口,然后根据点击执行对应的js方法 layer.confirm("我是弹出来的字", {btn:['确认','取消']}, function(){ ...方法1 ...
随机推荐
- [转] Ubuntu 14.04/14.10下安装VMware Workstation 11图文教程
点击这里查看原文 译者:GuiltyMan 本文由 Linux公社翻译组 原创翻译 Linux公社 诚意奉献 更多请访问此处博客网站 VMware workstation 是一个可以进行桌面操作的虚 ...
- Oracle11g在Windows和Linux下imp导入表,exp导出表,sqluldr2导出表,sqlldr导入表
Windows(Win10) 打开cmd 首先输入sqlplus,依次输入用户名.口令 C:\Users\hasee>sqlplus SQL*Plus: Release Production o ...
- 默 of 2018:年终总结
目录 1 概述:在平凡中求变 2 专业分流:一个时代的终点,我的新起点 2.1 我在专业分流前夕的境况 2.2 专业分流情况概述,以及对一篇文章的回顾 2.3 总结与余绪 2.4 附:关于理科与工科的 ...
- 我理解的js中预解释
浏览器在执行代码前,先找带var和带function的地方,把带var的声明且赋予初始值undefined,把带function的声明且定义. 带var关键字预解释 让我们先看下这段代码执行的结果: ...
- 浅析人脸检测之Haar分类器方法:Haar特征、积分图、 AdaBoost 、级联
浅析人脸检测之Haar分类器方法 一.Haar分类器的前世今生 人脸检测属于计算机视觉的范畴,早期人们的主要研究方向是人脸识别,即根据人脸来识别人物的身份,后来在复杂背景下的人脸检测需求越来越大,人脸 ...
- 微信开放平台Android应用的签名
微信开放平台Android应用签名的本质便是我们签名文件keystore的MD5值. keytool -list -v -keystore qj_test.keystore 获得: 别名: naoli ...
- hdu 2612
Find a way Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total ...
- 中小型研发团队架构实践七:集中式日志ELK
一.集中式日志 日志可分为系统日志.应用日志以及业务日志,系统日志给运维人员使用,应用日志给研发人员使用,业务日志给业务操作人员使用.我们这里主要讲解应用日志,通过应用日志来了解应用的信息和状态,以及 ...
- 关于DNS缓存
- Code Signal_练习题_Array Replace
Given an array of integers, replace all the occurrences of elemToReplace with substitutionElem. Exam ...