0

我正在使用 SpriteKit 为 Apple Watch 编写应用程序,因此我无法访问 touchesBegan 之类的功能,我必须使用 WKTapGestureRecognizer 来检测点击,没什么大不了的,但我在检测节点上的点击时遇到问题。在我的 InterfaceController 我有:

@IBAction func handleTap(tapGestureRecognizer: WKTapGestureRecognizer){
    scene?.didTap(tapGesture: tapGestureRecognizer)
}

在我的场景文件中,我有

func didTap(tapGesture:WKTapGestureRecognizer) {
    let position = tapGesture.locationInObject()
    let hitNodes = self.nodes(at: position)
    if hitNodes.contains(labelNode) {
    labelNode.text = "tapped!"
}

问题是点击手势识别器给了我触摸点的绝对坐标(例如 11.0、5,0),而我的节点相对于屏幕中心定位(所以它的位置是 -0.99,-11.29,即使在屏幕的中心)因此点击不是在实际点击节点时点击节点,而是在我点击屏幕左上角时点击。我到处搜索,看起来这是这样做的方法,但我没有发现有人遇到同样的问题。该节点已通过编辑器添加。我究竟做错了什么?

4

1 回答 1

0

所以你有正确的想法。你弄错了,因为 hitNodes 是一个 SKNodes 数组。那些是新创建的。所以当你使用 hitNodes.contains 时 labelNode 的地址和正在比较的新创建的 SKNode 的地址会完全不同。因此,它永远不会被窃听。

这就是我要做的。这将在我的场景文件中。您的 InterfaceController 类是正确的。

func didTap(tapGesture:WKTapGestureRecognizer) {
    let position = tapGesture.locationInObject()
    if labelNode.contains(position) {
        labelNode.text = "tapped!"
    }
}

或者另一种方式是这样。我喜欢这种方式,因为在 WKInterfaceController 中只有一个函数,而且场景文件中不需要任何函数。

@IBAction func tapOnScreenAct(_ sender: WKGestureRecognizer) {
    if scene.labelNode.contains(sender.locationInObject()) {
        scene.labelNode.text = "tapped!"
    }    
}

无论哪种方式,两者都应该工作。如果您还有任何问题或澄清,请告诉我。

于 2021-07-29T04:43:11.503 回答