- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我想从 SCNNode 检索屏幕坐标,这样我就可以在 SpriteKit 叠加层中使用这些坐标。该节点是一个子节点。当我旋转父节点的枢轴 projectPoint 时返回乱码结果。
场景:
class ScenekitScene:SCNScene {
override init() {
super.init()
let nodeCamera = SCNNode()
nodeCamera.camera = SCNCamera()
rootNode.addChildNode(nodeCamera)
let geoPyramid = SCNPyramid(width: 0.2, height: 0.5, length: 0.2)
let nodeCenterOfUniverse = SCNNode(geometry: geoPyramid)
nodeCenterOfUniverse.position = SCNVector3(0, 0, -5)
nodeCenterOfUniverse.pivot = SCNMatrix4MakeRotation(CGFloat.pi/4, 0.0, 0.0, 1.0)
rootNode.addChildNode(nodeCenterOfUniverse)
let geoSphere = SCNSphere(radius: 0.3)
let nodePlanet = SCNNode(geometry: geoSphere)
nodePlanet.name = "planet"
nodePlanet.position = SCNVector3(2, 0, 0)
nodeCenterOfUniverse.addChildNode(nodePlanet)
}
required init?(coder aDecoder: NSCoder) {
fatalError("init(coder:) has not been implemented")
}
}
SCNSceneRenderDelegate:
extension ViewController:SCNSceneRendererDelegate {
func renderer(_ renderer: SCNSceneRenderer, didRenderScene scene: SCNScene, atTime time: TimeInterval) {
if let planet = scene.rootNode.childNode(withName: "planet", recursively: true) {
let position = planet.convertPosition(planet.position, to: scene.rootNode)
let screencoords = renderer.projectPoint(position)
print (screencoords)
# result:
# SCNVector3(x: 461.913848876953, y: 2.58612823486328, z: 0.808080852031708)
# y should clearly be more to the center of the screen somewhere between 100-200
}
}
}
有谁知道如何获得正确的屏幕坐标?
最佳答案
看起来世界坐标中的行星位置不正确。当我手动计算行星位置时,我得到了不同的结果,并且 projectPoints 像宣传的那样工作。 [我可能会发布一个关于 worldTransform 的不同问题]。
// using SIMD
let pivCou = float4x4(nodeCenterOfUniverse.pivot)
let posCou = float3(nodeCenterOfUniverse.position)
let posCou4 = float4(posCou.x, posCou.y, posCou.z, 1.0) // convert float3 to float4
let posPlanet = float3(nodePlanet.position)
let posPlanet4 = float4(posPlanet.x, posPlanet.y, posPlanet.z, 1.0)
let worldcoordinatesPlanet = posCou4 + posPlanet4 * pivCou
关于ios - 旋转 SCNNode.pivot 后 SceneKit projectPoint 不正确,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44430385/
这是错误: imgpts, jac = cv2.projectPoints(axis, rvecs, tvecs, mtx, dist) cv2.error: OpenCV(4.2.0) C:\pro
我不断收到 断言失败(0 Generate3DPoints() { std::vector points; float x,y,z; x=.5;y=.5;z=.5; points.p
为什么我的代码片段给我的投影点结果很奇怪? //Generate the one 3D Point which i want to project onto 2D plane vector point
我正在使用 cv::projectPoints 获取 3D 点 vector 的相应像素。 这些点都离得很近。 问题是,对于某些点,我得到了正确的像素坐标,但对于其他点,我得到了奇怪的负值,例如 -2
我正在尝试编写自己的 cv2.projectPoints 实现只是为了练习,我的实现没有达到预期的效果。 我假设针孔相机没有失真,所以我所做的就是将以下等式应用于我所有的平面物点。 假设在某个世界空间
我有一个面向相当于棋盘的相机。我知道点的世界 3d 位置以及相机图像上相应投影点的 2d 位置。所有的世界点都属于同一个平面。我使用 solvePnP: Matx33d camMat; Matx41d
当我使用下面的java代码和最简单的输入运行projectPoints函数时,我得到了我认为不正确的答案。我错过了什么吗? 我得到了这个答案 (x,y,z)= [{0.0, 1.0, 1.0}, {0
我正在尝试使用 OpenCV 量化相机校准的准确性。在我的程序中,我正在读取棋盘图案的图像并调用 calibrateCamera 函数来初步猜测我的相机内部和外部。我知道仅使用一张图像不会产生完美的校
我正在使用 OpenCV 的 calibrateCamera 并试图了解它如何计算重投影误差以及该误差代表什么。它似乎是投影点和测量图像点之间的(欧几里得)距离的 RMS——对吗?然而,最终的重投影误
我有一个 3D 世界,我正尝试使用 cv2.projectPoints 将其映射到 2D View ,但它并不像我预期的那样运行。我对 opencv、numpy 和矩阵操作的掌握很薄弱,所以我一定是在
我正在尝试在场景的父 View 上的球体上绘制一个框架,但由于某种原因,由 SCNScene.projectPoint 方法转换的点被置换了。 为简单起见,我在场景中心创建了一个半径为 2 的球体。球
我已按照 https://docs.opencv.org/master/d7/d53/tutorial_py_pose.html 上的教程进行操作基于在 https://docs.opencv.org
我想校准我的相机并绘制 xyz 轴。 (如此链接所示:http://docs.opencv.org/3.1.0/d7/d53/tutorial_py_pose.html) 不幸的是,我的校准有些奇怪,
根据我的理解,undistortPoints 在扭曲图像上获取一组点,并计算它们的坐标在同一图像的未扭曲版本上的位置。同样,projectPoints 将一组对象坐标映射到它们对应的图像坐标。 但是,
在相机校准中,我使用 calibrateCamera() 从校准图案的多个 View 中查找相机参数。它恰恰做了两件事: 1) 假设镜头畸变为零,估计封闭形式的初始相机参数。 2) 运行全局 Leve
我想从 SCNNode 检索屏幕坐标,这样我就可以在 SpriteKit 叠加层中使用这些坐标。该节点是一个子节点。当我旋转父节点的枢轴 projectPoint 时返回乱码结果。 场景: class
SceneKit 的 renderer(_:updateAtTime:) 在后台线程上运行。 Apple 已表示不要在 NSView 和主线程外的子类上调用任何方法。 projectPoint(_:)
我正在展示一个由 SceneKit 中的多个 SNNode 组成的 3d 模型。 我在 sceneview-overlay View 上显示一个 2D SpriteKit 节点。 2D 节点位置应始终
我是一名优秀的程序员,十分优秀!