- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我目前正在一个项目(Three.js 和 ArucoJS)上使用 threex.webar ( https://github.com/jeromeetienne/threex.webar )。现在,我正在尝试基于 AR 标记进行投影 (markerObject3D),但我希望它位于标记旁边,而不是标记上。
这是我使用 Three.js translatex() 实现的方法:
function render() {
translateMarker3D(markerObject3D);
movieMaterial.update();
backgroundTexture.update();
effect.render(scene, camera)
}
function translateMarker3D(marker3D) {
marker3D.translateX( 80 );
}
事情是:它有点工作。它闪烁很多,当它没有翻译时很好(所以:当它在标记旁边时会闪烁,但当它在标记上时会闪烁)。
我还尝试更改 aruco 的返回值(在 threex.jsarucommarker.js 中):
object3d.position.x = translation[0] + 80;
但它渲染完全一样,闪烁。
所以我的问题是:使用 Three.js 在 AR 标记旁边进行投影的最佳方法是什么?
编辑:
由于现场演示很难设置,我刚刚在 Youtube 上上传了一段视频来说明我的观点:https://www.youtube.com/watch?v=SM1dZ29SZRk&feature=youtu.be
但是,您可以在此处查看完整代码:https://github.com/cned-di-dev/three-ar-proto/blob/master/tests/stereoscopic/index.html
我错过了什么:
需要知道的事情:我不太擅长 3D 东西(几何、矩阵等)。
最佳答案
有点难以理解“闪烁”的意思。但是经过一些测试,我想我明白你的意思了。我认为问题在于 detectMarkers()
函数无法在每一帧中找到精确相同的标记位置,并且首先旋转 markerObject,然后然后 翻译。
由于标记在每一帧的旋转中都会有一个小的变化,并且会沿其新 x 轴平移,因此标记对象会上下跳动,并且幅度会大于你进一步翻译它。
现在,解决方案取决于您对此翻译行为的要求。一种方法是只沿全局 x 轴平移 markerObject。这可以通过给 markerObject 一个父对象并翻译它来实现:
var markerParent = new THREE.Object3D();
var markerObject3D = new THREE.Object3D();
markerParent.add(markerObject3D);
markerParent.translateX(80); // you can do this just one time
scene.add(markerParent)
另一种方法是更改 markerToObject3D(marker, object3d)
源代码中的转换顺序,以便在旋转之前完成转换(并将转换添加到 object3d.position.x ).
如果您不想沿全局 x 轴平移 markerObject,而是沿其局部平移,则消除闪烁会有点困难。一种方法是为 markerObject 提供最后几帧的平均翻译,而不是让 JsArucoMarker
为每一帧计算一个新的翻译。或者,也许更好,给它最后几帧的平均旋转。
另一种使运动更平滑的方法是在每一帧内插其位置,这将减少“跳跃”
编辑
这仅说明了绕局部 z 轴旋转的杠杆作用,但绕 x 和 y 轴旋转也是如此。翻译会让markerdetection的error看起来更大。正如我之前所说,您可以通过为 markerObject 提供最后几帧的平均翻译来稍微隐藏这种效果。
我还注意到标记有时会“嗖”的一声移到一边。这也是因为 markerDetection 并不完美,在某些帧中,它根本找不到标记。当它没有找到标记时,您仍然将 markerObject 平移 40,加上上一帧完成的平移。你应该做的是:
删除第 359 行:
translateMarker3D(markerObject3D);
并将其添加到第 323 行:
markerObject3D.translateX(40);
通过这样做,您可以翻译 markerObject 只有当它可以检测到标记时。
关于javascript - 三.js : Best way to translate the projection?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36008855/
FogBugz 有没有办法创建一个过滤器,它是: [All] [open] [cases] assigned to [Developer A] with the exception of 1 or m
我是 java hibernate 的新手,我无法理解 Projections.property 和 Projections.groupProperty 之间的区别,两者都给出相同的结果。请解释其中的
让我们再试一次。我发布这个是为了回答 2 个问题 MS Project 2007 是否需要 SharePoint(我希望没有)? 做 你喜欢 MS Project 开发团队 - 它是有用的还是 疼痛?
我们的项目结构如下: sharedlib (lib-project, containing classes, that are useful in many apps) -> main-project
我正在尝试获取有关如何将 MS Project 2010 连接到 MS Project Server 2010 的教程或分步说明。 我已经在我的服务器上安装了 Server 2008 R2(64 位)
Projections.distinct(Projections.count("objectId")) 和 Projections.countDistinct("objectId") 谁能告诉我它们之
可以在项目 “project-a” 中创建一个主题“my-topic-project-a”,这样它就可以公开可见(已完成通过将角色“pub/sub subscriber” 设置为“allUsers”)
我创建了一个简单的 Kafka 消费者,它返回 Flux对象(收到的消息),我正在尝试使用 StepVerifier 对其进行测试. 在我的测试中,我做了这样的事情: Flux flux = cons
我有一个项目,最初是在 Eclipse 中,然后我设法将它转换为 gradle,并且在 Android Studio 中一切正常。 但后来我没有在这个项目上工作一段时间,几个月后当我回到项目时,我很惊
我正在研究 CQRS/ES 架构。我们将多个异步投影并行运行到读取存储中,因为某些投影可能比其他投影慢得多,并且我们希望与写入端保持更多同步以实现更快的投影。 我试图了解有关如何生成读取模型以及这可能
第一次尝试使用 Java 持久性注释创建多对多关系。 场景:Java 类Project 包含子项目,它只是Projects 的List。没有反向(没有 super 项目)成员。所以我认为多对多关系对于
我有现有的 C 代码和现有的 Makefile,我想将其包装到 Eclipse C 项目中(使用 Eclipse 3.4 Ganymede)。代码组织如下: 主目录:/Project/Software
我有一个 Eclipse 项目,不久前我设法在 Android Studio 中工作。它使用 TouchDB 库/项目,我现在想升级到他们最新的产品 couchbase-lite-android,看起
我将项目定义为包含主干、分支、标签子目录的 SVN 目录。 在确定何时将项目拆分为两个或将多个项目合并为一个时,您使用什么标准? - 每个“项目”一个应用程序,具有用于公共(public)源和资源的共
尝试在 Visual Studio 2008 中构建解决方案时遇到此错误。这是什么意思? 最佳答案 这可能意味着文件 bin\project.dll被另一个进程(可能是另一个 Visual Studi
此宏将隐藏/关闭 VBE 主窗口: Sub VBEMainWindowHide() 'close VBE window: Application.VBE.Window.Visible
我正在寻求开发户外应用程序,但不确定 tango 平板电脑是否可以在户外使用。那里的其他深度设备往往在室外效果不佳,因为它们依赖于从设备转换的红外光,然后在它从场景中的物体反射回来后进行观察。我一直在
在标准 .csproj您可以进入属性并设置默认命名空间。如何在 .xproj 中实现这一点项目使用 project.json ? 最佳答案 使用 ASP.NET Core 1.0.1,您可以在 pro
当 Redmine 上注册的项目超过 5 个时,主页“最新项目”框中列出的项目按创建日期降序排序(最近创建的优先),将旧项目(可能更新频率更高)排除在列表之外. 有没有办法按事件从最高到最低列出前 5
我开始学习android开发,但我不知道如何将库添加到项目中。我使用安卓工作室。我创建了新项目,但项目结构中没有项目设置。 最佳答案 在“项目”窗口中右键单击您的包名称,然后选择“打开模块设置”。这应
我是一名优秀的程序员,十分优秀!