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

类似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)
            }
        }
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容