Skip to content

JoanKing/JKVerifyCodeView

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

23 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

JKVerifyCodeView

CI Status Version License Platform

Requirements

Swift5.0+

Installation

JKVerifyCodeView is available through CocoaPods. To install it, simply add the following line to your Podfile:

pod 'JKVerifyCodeView'

视图层级

  • 最底层一个隐藏的UITextView,上面铺的Label
  • 输入焦点在UITextView,监听UITextView的输入,给Label赋值
  • 通过Label显示输入的文字使用CAShapeLayer绘制光标
  • 通过光标的显示隐藏来控制光标的移动
  • 基础动画控制光标闪动

使用说明

效果图

  • 1、先定义一个 JKVerifyCodeStyle,设置整体的样式, 样式如下
public class JKVerifyCodeStyle: NSObject {

    /// 输入框没有获取焦点的颜色
    public var lineViewNormalColor: UIColor = UIColor(hexString: "#EBEBEB")
    /// 输入框获取焦点的颜色
    public var lineViewFocusColor: UIColor = UIColor(hexString: "#999999")
    /// 光标的颜色
    public var cursorColor: UIColor = UIColor(hexString: "#FF4600")
    /// 每个验证码输入框间距
    public var spacing: CGFloat = 10
    /// 验证码输入框距离两边的边距
    public var padding: CGFloat = 0
    /// 验证码的字体
    public var numLabelFontSize: UIFont = UIFont.systemFont(ofSize: 28)
    /// 验证码的字体
    public var numLabelTextColor: UIColor = UIColor(hexString: "#333333")
}
  • 2、展示整个界面,监听输入的过程
// 监听验证码输入的过程
codeView.textValueChange = { str in
    print("输入中:\(str)")
}
    
// 监听验证码输入完成
codeView.inputFinish = { str in
    print("输入完成:\(str)")
}
  • 3、类型目前支持两种:下划线和方格

    下划线样式 方格类型 方格类型加密

Author

JoanKing, jkironman@163.com

License

JKVerifyCodeView is available under the MIT license. See the LICENSE file for more info.

版本记录

  • 0.1.5(2023.02.22):支持输入框个数自定义
  • 0.1.2:新增方格类型的样式,支持数据是否加密
  • 0.1.0:支持下划线的样式