https://github.com/Boris-Em/BEMCheckBox
https://github.com/Boris-Em/BEMCheckBox
BEMCheckBox
BEMCheckBox is an open source library making it easy to create beautiful, highly customizable, animated checkboxes for iOS.
Table of Contents
Project Details
Learn more about the BEMCheckBox project, licensing, support etc.
Requirements
- Requires iOS 7 or later. The sample project is optimized for iOS 9.
- Requires Automatic Reference Counting (ARC).
- Optimized for ARM64 Architecture.
License
See the License. You are free to make changes and use this in either personal or commercial projects. Attribution is not required, but highly appreciated. A little "Thanks!" (or something to that affect) is always welcome. If you use BEMCheckBox in your app, please let us know!
Support
Join us on Gitter if you need any help or want to talk about the project.
Sample App
The iOS Sample App included with this project demonstrates one way to correctly setup and use BEMCheckBox. It also offers the possibility to customize the checkbox within the app.
React Native
BEMCheckBox can be used with React Native: React-Native-BEMCheckBox
Xamarin
BEMCheckBox can also be used with Xamarin: XPlugins.iOS.BEMCheckBox
Getting Started
It only takes a few simple steps to install and setup BEMCheckBox to your project.
Installation
CocoaPods
The easiest way to install BEMCheckBox is to use CocoaPods. To do so, simply add the following line to your Podfile
:
pod 'BEMCheckBox'
Carthage
Carthage is a decentralized dependency manager that builds your dependencies and provides you with binary frameworks.
Run carthage update
after adding BEMCheckBox to your Cartfile to build the framework. Drag the built BEMCheckBox.framework
into your Xcode project.
Manually
Finally, you can install BEMCheckBox manually. Simply drag and drop the Classes folder into your Xcode project. When you do so, make sure to check the "Copy items into destination group's folder" box.
Setup
Setting up BEMCheckBox to your project couldn't be more simple. It is modeled after UISwitch
. In fact, you could just replace instances of UISwitch
by BEMCheckBox in your project!
Here are the steps to follow to get everything up and running:
- Import
"BEMCheckBox.h"
to the header of your view controller:
#import "BEMCheckBox.h"
- BEMCheckBox can either be initialized programatically (through code) or with Interface Builder (Storyboard file). Use the method that makes the most sense for your project.
Programmatical Initialization
Just add the following code to your implementation (usually in the viewDidLoad
method of your View Controller).
BEMCheckBox *myCheckBox = [[BEMCheckBox alloc] initWithFrame:CGRectMake(0, 0, 50, 50)];
[self.view addSubview:myCheckBox];
Interface Builder Initialization
1 - Drag a UIView
to your UIViewController
.
2 - Change the class of the new UIView
to BEMCheckBox
.
3 - Select the BEMCheckBox
and open the Attributes
Inspector. Most of the customizable properties can easily be set from
the Attributes Inspector. The Sample App demonstrates this capability.
Documentation
All of the methods and properties available for BEMCheckBox are documented below.
Enabling / Disabling the Checkbox
The on
Property
Just like UISwitch
, BEMCheckBox provides the boolean property on
that allows you to retrieve and set (without animation) a value determining wether the BEMCheckBox object is on
or off
. Defaults to NO
.
Example usage:
self.myCheckBox.on = YES;
setOn:animated:
Just like UISwitch
, BEMCheckBox provides an instance method setOn:animated:
that sets the state of the checkbox to On or Off, optionally animating the transition.
Example usage:
[self.myCheckBox setOn:YES animated:YES];
Reloading
The instance method reload
lets you redraw the entire checkbox, keeping the current on
value.
Example usage:
[self.myCheckBox reload]
Group / Radio Button Functionality
BEMCheckBoxes can easily be grouped together to form radio button functionality. This will automatically manage the state of each checkbox in the group, so that only one is selected at a time, and can optionally require that the group has a selection at all times.
self.group = [BEMCheckBoxGroup groupWithCheckBoxes:@[self.checkBox1, self.checkBox2, self.checkBox3]];
self.group.selectedCheckBox = self.checkBox2; // Optionally set which checkbox is pre-selected
self.group.mustHaveSelection = YES; // Define if the group must always have a selection
To see which checkbox is selected in that group, just ask for it:
BEMCheckBox *selection = self.group.selectedCheckBox;
To manually update the selection for a group, just set it:
self.group.selectedCheckBox = self.checkBox1;
Delegate
BEMCheckBox uses a delegate to receive check box events. The delegate object must conform to the BEMCheckBoxDelegate
protocol, which is composed of two optional methods:
didTapCheckBox:
Sent to the delegate every time the check box gets tapped, after its properties are updated (on
), but before the animations are completed.animationDidStopForCheckBox:
Sent to the delegate every time the check box finishes being animated.
Customization
BEMCheckBox is exclusively customizable though properties.
The following diagram provides a good overview:
Apparence Properties
lineWidth
- CGFloat
The width of the lines of the check mark and box. Defaults to 2.0.
`hideBox` - BOOL
BOOL to control if the box should be hidden or not. Setting this
property to `YES` will basically turn the checkbox into a check mark.
Defaults to `NO`.
boxType
- BEMBoxType
The type of box to use. See BEMBoxType
for possible values. Defaults to BEMBoxTypeCircle
.
tintColor
- UIColor
The color of the box when the checkbox is Off.
onCheckColor
- UIColor
The color of the check mark when it is On.
onFillColor
- UIColor
The color of the inside of the box when it is On.
onTintColor
- UIColor
The color of the line around the box when it is On.
Animations
animationDuration
- CGFloat
The duration in seconds of the animations. Defaults to 0.5
.
onAnimationType
- BEMAnimationType
The type of animation to use when the checkbox gets checked. Defaults to BEMAnimationTypeStroke
. See BEMAnimationType
bellow for possible values.
offAnimationType
- BEMAnimationType
The type of animation to use when the checkbox gets unchecked. Defaults to BEMAnimationTypeStroke
. See BEMAnimationType
bellow for possible values.
BEMAnimationType
The possible values for onAnimationType
and offAnimationType
.
BEMAnimationTypeStroke
BEMAnimationTypeFill
BEMAnimationTypeBounce
BEMAnimationTypeFlat
BEMAnimationTypeOneStroke
BEMAnimationTypeFade
https://github.com/Boris-Em/BEMCheckBox的更多相关文章
- 转载请注明出处: https://github.com/qiu-deqing/FE-interview
转载请注明出处: https://github.com/qiu-deqing/FE-interview Table of Contents generated with DocToc FE-inter ...
- https://github.com/chenghuige/tensorflow-exp/blob/master/examples/sparse-tensor-classification/
https://github.com/chenghuige/tensorflow-exp/blob/master/examples/sparse-tensor-classification/ ...
- fatal: could not read Username for 'https://github.com': No such file or directo
Git push origin master报错 fatal: could not read Username for 'https://github.com': No such file or di ...
- 结合个人经历总结的前端入门方法 (转自https://github.com/qiu-deqing/FE-learning)
结合个人经历总结的前端入门方法 (https://github.com/qiu-deqing/FE-learning),里面有很详细的介绍. 之前一直想学习前端的,都不知道怎么下手都一年了啥也没学到, ...
- (2016 年) githup 博客地址 : https://github.com/JMWY/MyBlog
githup 博客地址 : https://github.com/JMWY/MyBlog
- MJExtension的使用:https://github.com/CoderMJLee/MJExtension
MJExtension能做什么? MJExtension是一套字典和模型之间互相转换的超轻量级框架 MJExtension能完成的功能 字典(JSON) --> 模型(Model) 模型(Mod ...
- MBProgressHUD框架的使用:https://github.com/jdg/MBProgressHUD
MBProgressHUD是一个开源类库,实现了各种样式的提示框, 下载地址:https://github.com/jdg/MBProgressHUD,然后把两个MBProgressHUD.h和MBP ...
- https://github.com/akullpp/awesome-java
java stack https://github.com/akullpp/awesome-java
- https://github.com/oneuijs/You-Dont-Need-jQuery
https://github.com/oneuijs/You-Dont-Need-jQuery
随机推荐
- vuex与redux,我们都一样
vuex与redux的主要区别: redux:生成的全局数据流是通过每个组件的props逐层传递到各个子组件的,通过@connect装饰器绑定在this.props上面. vuex :生成的全局数据则 ...
- Linux常用命令——关机与重启命令
1.shutdown命令 shutdown [选项] 时间 --使用shutdown进行关机或重启会正确保存正在使用的服务,其他命令有一定的危险性,建议最好使用shutdown命令进行关机重启 选项: ...
- 字符串、散列--P1598 垂直柱状图
题目描述 写一个程序从输入文件中去读取四行大写字母(全都是大写的,每行不超过100个字符),然后用柱状图输出每个字符在输入文件中出现的次数.严格地按照输出样例来安排你的输出格式. 输入输出格式 输入格 ...
- 【阶梯报告】洛谷P3391【模板】文艺平衡树 splay
[阶梯报告]洛谷P3391[模板]文艺平衡树 splay 题目链接在这里[链接](https://www.luogu.org/problemnew/show/P3391)最近在学习splay,终于做对 ...
- Python爬虫入门教程: 27270图片爬取
今天继续爬取一个网站,http://www.27270.com/ent/meinvtupian/ 这个网站具备反爬,so我们下载的代码有些地方处理的也不是很到位,大家重点学习思路,有啥建议可以在评论的 ...
- Python网络编程—socket(二)
http://www.cnblogs.com/phennry/p/5645369.html 接着上篇博客我们继续介绍socket网络编程,今天主要介绍的内容:IO多路复用.多线程.补充知识点. 一.I ...
- 百练4152:最佳加法表达式(dp+高精度)
描述 给定n个1到9的数字,要求在数字之间摆放m个加号(加号两边必须有数字),使得所得到的加法表达式的值最小,并输出该值.例如,在1234中摆放1个加号,最好的摆法就是12+34,和为36 输入有不超 ...
- DESEncrypt对称加密解密
分享一个很好用的DESEncrypt对称加密解密的类 using System; using System.Security.Cryptography; using System.Text; usin ...
- 小L 的二叉树(洛谷 U4727)
题目背景 勤奋又善于思考的小L接触了信息学竞赛,开始的学习十分顺利.但是,小L对数据结构的掌握实在十分渣渣. 所以,小L当时卡在了二叉树. 题目描述 在计算机科学中,二叉树是每个结点最多有两个子结点的 ...
- 矩形面积求并(codevs 3044)
题目描述 Description 输入n个矩形,求他们总共占地面积(也就是求一下面积的并) 输入描述 Input Description 可能有多组数据,读到n=0为止(不超过15组) 每组数据第一行 ...