美文网首页
IOS Swift使用闭包实现View点击,长按事件

IOS Swift使用闭包实现View点击,长按事件

作者: 暮商知秋 | 来源:发表于2020-12-18 16:34 被阅读0次

类似Android上设置view的点击,长按监听器

使用

       let label = UILabel()
       label.text = "测试"
        
        self.view.backgroundColor = UIColor.green
        self.view.addSubview(label)
        label.snp.makeConstraints { (make) in
            make.top.equalToSuperview().offset(0)
            make.width.equalTo(200)
            make.height.equalTo(80)
        }
        label.backgroundColor = UIColor.red
        
        label.addOnClick { (view) in
            ToastUtil.show("click")
        }
        
        label.addOnLongPress { (view) in
            ToastUtil.show("long press")
        }

实现原理

使用swift扩展,关联属性,闭包

import UIKit
import Foundation

extension UIView {
    //单击事件
    typealias OnClickListener = (UIView) -> Void
    //长按事件
    typealias OnLongPressListener = (UIView) -> Void
    
    private struct AssociatedKeys {
        static var clickKey = "UIView.click"
        static var longPressKey = "UIView.onpress"
    }

    var clickListener: OnClickListener? {
        get {
            return objc_getAssociatedObject(self, &AssociatedKeys.clickKey) as? OnClickListener
        }
        set (listener) {
            objc_setAssociatedObject(self, &AssociatedKeys.clickKey, listener, .OBJC_ASSOCIATION_RETAIN_NONATOMIC)
        }
    }
    
    var longPressListener: OnLongPressListener? {
        get {
            return objc_getAssociatedObject(self, &AssociatedKeys.longPressKey) as? OnLongPressListener
        }
        set (listener) {
            objc_setAssociatedObject(self, &AssociatedKeys.longPressKey, listener, .OBJC_ASSOCIATION_RETAIN_NONATOMIC)
        }
    }
    
    func addOnClick(listener: OnClickListener?) -> Void {
        let tapGes = UITapGestureRecognizer(target: self, action: #selector(onClick))
        tapGes.numberOfTapsRequired = 1
        self.addGestureRecognizer(tapGes)
        self.isUserInteractionEnabled = true
        clickListener = listener
    }
    
    func addOnLongPress(listener: OnLongPressListener?) -> Void {
        let longPress = UILongPressGestureRecognizer(target: self, action: #selector(onLongPress))
        longPress.minimumPressDuration = 1
        self.addGestureRecognizer(longPress)
        self.isUserInteractionEnabled = true
        longPressListener = listener
    }
    
    @objc func onClick(sender: UITapGestureRecognizer) -> Void {
        if let listener = clickListener {
            listener(self)
        }
    }
    
    @objc func onLongPress(sender: UILongPressGestureRecognizer) -> Void {
        print(sender.state);
        if (sender.state == UIGestureRecognizer.State.began) {
            if let listener = longPressListener {
                listener(self)
            }
        }
    }
}

相关文章

网友评论

      本文标题:IOS Swift使用闭包实现View点击,长按事件

      本文链接:https://www.haomeiwen.com/subject/smffnktx.html