首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用Catalyst实现onHover事件?

如何使用Catalyst实现onHover事件?
EN

Stack Overflow用户
提问于 2020-01-31 17:59:38
回答 2查看 882关注 0票数 0

使用swiftUI的Catalyst有可能发生鼠标onHover事件吗?

目前仅支持macOS版本的onHover(perform:)

EN

回答 2

Stack Overflow用户

发布于 2020-03-19 06:00:44

这是一个干净的Catalyst解决方案,但这可能很快就会在iPadOS/Catalyst 13.4中出现。在任何情况下使用相同的:

代码语言:javascript
复制
someView.onHover2 { doSomething(isHovering: $0) }

支持这一点的代码:

代码语言:javascript
复制
import SwiftUI

extension View {
    func onHover2(perform action: @escaping (Bool) -> Void) -> some View {
        return self.overlay(HoverRecognizer(action: action))
    }
}

public struct HoverRecognizer: UIViewRepresentable {

    var action: (Bool) -> Void

    public func makeUIView(context: Context) -> UIView {
        return HoverView(action)
    }

    public func updateUIView(_ uiView: UIView, context: Context) {
    }

    private class HoverView: UIView {
        var action: (Bool) -> Void

        init(_ action: @escaping (Bool) -> Void) {
            self.action = action
            super.init(frame: CGRect.zero)

            self.addGestureRecognizer(UIHoverGestureRecognizer(
                target: self,
                action: #selector(hovering(_:))))
        }

        required init?(coder: NSCoder) {
            fatalError("init(coder:) has not been implemented")
        }

        @objc
        func hovering(_ recognizer: UIHoverGestureRecognizer) {
            switch recognizer.state {
                case .began, .changed:
                    action(true)
                case .ended:
                    action(false)
                default:
                    break
            }
        }
    }
}
票数 3
EN

Stack Overflow用户

发布于 2020-02-18 10:43:43

代码语言:javascript
复制
class SomeOfMyView: UIView {
    // 1. Make sure you save default color upon init
    var color: UIColor?
    required init?(coder: NSCoder) {
        super.init(coder: coder)
        DispatchQueue.main.asyncAfter(deadline: .now() + 0.2) {
            if #available(iOS 13.0, *) {
                // 2. add hover gesture
                let hover = UIHoverGestureRecognizer(target: self, action: #selector(self.hovering(_:)))
                self.addGestureRecognizer(hover)
                // 3. saving default color
                self.color = self.backgroundColor
            }
        }
    }

    @available(iOS 13.0, *)
    @objc func hovering(_ recognizer: UIHoverGestureRecognizer) {
        // 4. upon hover we change color.
        switch recognizer.state {
            case .began, .changed:
                backgroundColor = .lightGray
            case .ended:
                backgroundColor = color
            default:
                backgroundColor = color
        }
    }
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/60001653

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档