4

如何检测 MacBook 触控板上的两个手指缩放手势?(在选定的 NSView 内)

4

3 回答 3

5

一个简单的快速解决方案:

var zoom:CGFloat = 0
override func magnify(with event: NSEvent) {
    super.magnify(with: event)
    if(event.phase == .changed){
        zoom += event.deltaZ
    }else if(event.phase == .began){
        zoom = 0//reset
    }else if(event.phase == .ended){
        //Swift.print("zoom: " + "\(zoom)")
        var dir:Int
        if(zoom < -100){
            Swift.print("zoom out")
            dir = 1
        }else if(zoom > 100){
            Swift.print("zoom in")
            dir = -1
        }else{
            Swift.print("no zoom")
            dir = 0
        }
    }
}

它检测是否发生了缩放手势 +-100 deltaZ (又名捏合缩放)

围绕这种方法的更多信息和研究:http:
//eon.codes/blog/2016/02/10/Gesture-research/

于 2017-03-24T17:47:16.573 回答
4

有一种用于捏合手势的事件类型 ( NSEventTypeMagnify),以及一种用于处理此类事件的NSResponder方法 ( )。-magnifyWithEvent:Cocoa 在这方面与 Cocoa Touch 有点不同。在桌面上,您通常让操作系统为您解释手势,并且您响应手势的含义而不是尝试识别手势本身。

于 2015-02-05T06:09:35.457 回答
4

更新的 Swift 解决方案

由于 deltaZ 似乎已被弃用(我使用 macOS 10.13.6 aka High Sierra,Xcode 9.4.1),因此 eonist 的答案似乎有些过时。解决方案是针对 NSScrollView。

override func magnify(with event: NSEvent) {
    if(event.phase == .changed){
        onZoomChanged(magnification: self.magnification * (1 + event.magnification))
    }
}

func onZoomChanged(magnification: CGFloat) {
    allowsMagnification = true
    let centerPos =  documentVisibleRect.midPoint // midPoint is a simple CGRect extension
    setMagnification(magnification, centeredAt: centerPos)
}
于 2018-07-28T07:21:05.250 回答