1

我目前正在研究允许我在另一台设备的浏览器上流式传输“耳机所看到的内容”的东西。我正在使用 A-frame (v 1.2.0) 体验和 Oculus Quest。我使用 Socket.io 和 Web rtc 建立连接并在参与者之间发送流,到目前为止一切正常

我基于此示例的代码来流式传输画布的内容:

https://developers.google.com/web/updates/2016/10/capture-stream

像这样 :document.querySelector("canvas").captureStream(30);

一旦套接字建立了对等连接,我就会用 webrtc 发送它。一切正常,我可以通过我定义的相机从浏览器(查看器端)看到场景:

<a-entity id="rig" position="0 1.6 5">
    <a-entity id="head" camera look-controls">
    </a-entity>
</a-entity>

当我们在 2D 模式下(在 PC 浏览器上或在耳机上进入 VR 模式之前)使用鼠标拖动移动相机时,流跟随得非常好

但是当耳机用户进入 VR 模式时,摄像头并没有跟随用户的眼睛。(但是当我移动控制器时,我可以看到我的光线投射器的激光在移动)

我做了一些测试来理解,我看到“手动更新”相机的旋转正在工作:我制作了一个组件,允许我用操纵杆旋转相机的 Y 轴,它在流上也能很好地工作,我的意思是它证明了我指的是好相机。这是否意味着耳机没有更新我的相机轴?

该相机具有绑定到自身的核心“外观控制”组件。

https://aframe.io/docs/1.2.0/components/look-controls.html

我在官方文档上阅读了这个并看到:

当我们旋转 VR 头戴式显示器 (HMD) 时旋转实体。

这似乎回答了我的问题,但对我不起作用。我尝试了该组件的几乎所有属性,例如强制/检查“hmdEnabled”属性是否设置为 true,但我无法使其工作。

4

0 回答 0