- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正试图在使用 webvr-boilerplate 的项目中使镜像效果正常工作当 VREffect 处于事件状态时。
我尝试(使用 r72dev 和 r72)使用 THREE.Mirror:
//webVR-boilerplate + Mirror.js
verticalMirror = new THREE.Mirror( renderer, camera, { clipBias: 0.03, textureWidth: 256, textureHeight: 256, color:0x889999 } );
verticalMirrorMesh = new THREE.Mesh( new THREE.PlaneBufferGeometry( 10, 10 ), verticalMirror.material );
verticalMirrorMesh.add( verticalMirror );
scene.add( verticalMirrorMesh );
// Request animation frame loop function
function animate( timestamp ) {
verticalMirror.render();
// Update VR headset position and apply to camera.
controls.update();
// Render the scene through the manager.
manager.render( scene, camera, timestamp );
requestAnimationFrame( animate );
}
当激活 VR 模式并且立体观看处于事件状态时,渲染目标停止更新。
镜子在相机后面,我设置了一个旋转的模型来观察镜子的行为。
有没有想过为什么会发生这种情况以及可能的解决方法?我是否遗漏了一些镜像或立体效果的初始化参数?
提前致谢。
编辑:似乎问题不仅发生在 webvr-boilerplate 上,而且也发生在 StereoEffect.js 和 Mirror.js 上,因为我使用镜像设置场景到 three.js StereoEffect.js example还是一样的问题..
Stereo http://ruidorey.webfactional.com/stereo.png mirror WITH stereo effect - live example
No Stereo http://ruidorey.webfactional.com/nostereo.png mirror WITHOUT stereo effect - live example
最佳答案
当您进入 VR 模式时,镜像会中断,因为您设置了 WEBVR_FORCE_DISTORTION
标志。这导致 webvr-boilerplate 的 WebVRManager 使用它自己的 CardboardDistorter shim(与实现 WebVR 的浏览器中的失真支持相反)。这会干扰镜像渲染。
CardboardDistorter 劫持渲染器并强制它绘制到属于扭曲器的渲染目标。这可以防止镜像使用它自己的渲染目标。
理想情况下,WebVRManager 应该得到修复,以便它支持开箱即用的镜像,但您可以通过存储原始渲染函数并在镜像渲染步骤中使用它来解决此问题:
var renderer = new THREE.WebGLRenderer({antialias: true});
// Save the original render function, so that we can use it
// even after CardboardDistorter hijacks the renderer.
var originalRenderFunc = renderer.render;
...
function animate(timestamp) {
...
// In our animation loop, restore the original render
// function for the mirror to use.
var hijackedRenderFunc = renderer.render;
renderer.render = originalRenderFunc;
verticalMirror.render();
// Set the render function back to the hijacked version
// so that CardboardDistorter can do its job.
renderer.render = hijackedRenderFunc;
...
}
关于javascript - three.js - THREE.StereoEffect/webVR-样板 + THREE.Mirror,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32503711/
我正在创建一个 SSO 服务器,以将所有用户集中在 ActiveDirectory(AD) 中并在那里管理他们,而不是每个特定应用程序的数据库。 为了制作这个服务器,我使用了 IdentityServ
几天前,我了解了 HTML5 样板文件,所以我还是个新手。我正在尝试使用样板进行试验,所以我继续下载了这个 boilerplate 但我对下载选项的差异感到困惑。 有一个用于下载现成的自定义文件的按钮
在Flutter中,我们需要为在dispose()中创建的许多内容写下State,例如 final _nameController = TextEditingController(); @ov
我正在开发一个更大的项目,我对空检查有点厌倦。我有一个 MongoDB 实体(文档),该实体引用了另一个文档。几乎在每种情况下,我都会检查它是否为空,如果不是则执行某些操作。我知道 Java 8 中有
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,
每次我向项目中添加新表单时,它都会在 use 子句中删除一大堆样板文件。 uses Windows, Messages, SysUtils, Variants, Classes, Graphics
这是我的Todo应用程序的基本结构,看起来像是“main.go”; package main import ( "encoding/json" "fmt" "log"
我有一个实现接口(interface)的类。还有另一个类也实现了这个接口(interface),并且第二个类的实例支持我的类的实现。 对于接口(interface)指定的许多方法,我的类只是将它们直接
每次我想要一个 SeekBar 和一个相应的 TextView 来显示它的数值时,为了减少代码的编写,我编写了以下抽象类: abstract public class SeekBarWrapper {
我正在考虑使用 CSS 样板(kube 或任何其他)来构建我的表单。它们在示例 html 文件中工作得很好,但是如果我想在不受控制的环境中使用(意味着 css 不在我的控制范围内),它会弄乱这些样式。
我很难在 CSS 中显示我的背景图片。我创建了一个带有 .top 类的 div,但每次我使用 background-image css 属性时,除了颜色、高度和宽度外什么都没有显示。我还使用 Init
尝试使用yarn导入react-image-crop包并将其添加到react样板中。 安装包后出现此错误 Module parse failed: /Users/...../frontend/node
我正在使用 skeleton 构建网站框架,使用 a fork that compiles from LESS . 在不丢失骨架提供的底层脚手架的情况下自定义样式的正确方法是什么?我知道我可以更改变量
从开箱即用的 HTML5 样板安装中,我使用以下代码 body { background-image:url('img/bg.png'); background-repeat:repeat-y; }
我正在使用 GWT 事件和地点框架来构建我的应用程序,结果很好。让我烦恼的一件事是 ActivityMapper实现是 (1) 接收应用程序中的所有 View (2) 包含一个巨大的 if/else
我正在使用generator-babel-boilerplate然后运行npm run test-browser。这可以正常工作,但我需要在浏览器中测试一些内容,并且我不确定如何查看正在提供的内容。
我经常使用以下样板,并希望将其消除。它看起来像这样: type Configured = ReaderT Config doSomething :: Configured IO Data doSome
我正在使用 ASP.NET 样板。我有一个 Angular 应用程序(ABP 外部),我想使用我的 API。 为此,我通过 /api/TokenAuth/Authenticate 获取访问 token
我的 JS 为: (function () { var controllerId = 'app.views.dashboard'; angular.module('app').cont
我们曾经可以输入 !在 vscode 中的 html 文档中获取 html boiler plate content completion as documented here . 然而它不再起作用。
我是一名优秀的程序员,十分优秀!