- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
任何人都知道是否可以在 Web Worker 中合并一组立方体几何图形并将其传递回主线程?认为这可以减少合并大量立方体时的延迟。
Three.JS 在 Web Worker 中是否可以正常工作,如果可以,是否可以(并且更快)执行此操作?不确定将几何体传回是否与正常合并一样长。
目前我正在使用定时 for 循环来减少延迟:
// This array is populated by the server and contains the chunk position and data (which I do nothing with yet).
var sectionData = data.secData;
var section = 0;
var tick = function() {
var start = new Date().getTime();
for (; section < sectionData.length && (new Date().getTime()) - start < 1; section++) {
var sectionXPos = sectionData[section][0] * 10;
var sectionZPos = sectionData[section][1] * 10;
var combinedGeometry = new THREE.Geometry();
for (var layer = 0; layer < 1; layer++) { // Only 1 layer because of the lag...
for (var x = 0; x < 10; x++) {
for (var z = 0; z < 10; z++) {
blockMesh.position.set(x-4.5, layer-.5, z-4.5);
blockMesh.updateMatrix();
THREE.GeometryUtils.merge(combinedGeometry, blockMesh);
}
}
}
var sectionMesh = new THREE.Mesh(combinedGeometry, grassBlockMat);
sectionMesh.position.set(sectionXPos, 0, sectionZPos);
sectionMesh.matrixAutoUpdate = false;
sectionMesh.updateMatrix();
scene.add(sectionMesh);
}
if (section < sectionData.length) {
setTimeout(tick, 25);
}
};
setTimeout(tick, 25);
最佳答案
THREE.JS 不能在 web worker 中工作,但是你可以复制那些你需要在主线程和 web worker 中工作的库部分。
您的第一个问题将是您无法将几何对象本身发送回主线程。
由于网络 worker onmessage 变量传递仅通过发送 JSON 副本(不是 javascript 对象)或对 ArrayBuffers 的引用来工作,因此您必须将几何图形解码为每个浮点数,将其打包在 ArrayBuffer 中,然后将引用发送回主线程。
请注意,这些被称为可转移对象,一旦发送,它们将在它们来自的 webworker/主线程中被清除。
请参阅此处了解更多详情:
http://www.html5rocks.com/en/tutorials/workers/basics/
https://developer.mozilla.org/en-US/docs/Web/Guide/Performance/Using_web_workers
以下是将位置顶点打包到物理类型系统数组中的示例:
//length * 3 axes * 4 bytes per vertex
var posBuffer = new Float32Array(new ArrayBuffer(len * 3 * 4));
//in a loop
//... do hard work
posBuffer[i * 3] = pos.x; //pos is a threejs vector
posBuffer[i * 3 + 1] = pos.y;
posBuffer[i * 3 + 2] = pos.z;
//after loop send buffer to main thread
self.postMessage({posBuffer:posBuffer}, [posBuffer.buffer]);
关于merge - 使用 WebWorker 合并几何图形?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16904383/
我无法将 wasm.instance.exports 对象发布到 WebWorkers 或从 WebWorkers 发布。任何帮助将不胜感激。 最佳答案 通过 postMessage API 发送的消
我正在使用 webworks 开发 Blackberry 10 App,我想使用 webworks 获取设备 IMEI 号码。我没有找到任何解决方案来在互联网上获取 IMEI 号码。 最佳答案 查看身
我无法使用安装在默认位置的 SDK 来构建 Ripple。我收到错误消息“Oh Snap!Build request failed with message: ./Applications/Black
我曾尝试在 Facebook 上分享,但无法分享任何内容。我使用的代码是:- 在 JavaScript 中 FB.init({ appId: 'some id',
因此,我尝试进行测试,看看 WebWorker 线程 ( https://github.com/audreyt/node-webworker-threads ) 可以在多核系统中使用 NodeJS 改
在网上搜索了很多天后,我从来没有找到我的问题的答案,甚至没有找到任何人设法做我正在尝试的事情。 我正在尝试在 Blackberry 的 WebWorks 应用程序中实现推送通知,但没有任何运气。我尝试
我有一个使用 Javascript 递归函数的第一个版本,它产生了预期的结果。下面是工作版本: // Call the recursive function and get final (a,b) r
我正在尝试从 Ripple 模拟器中打包并签署一个 BlackBerry webworks 应用程序(我也尝试过使用 bbwp)。 打包工作正常,但签名会返回非常有用的错误消息 [ERROR] Sig
调试网络 worker 的最佳方法是什么?我的工作人员似乎在某个地方出现了故障,但我似乎无法将内容记录到控制台来弄清楚发生了什么。有没有办法使用 firebug 或 webkit 的检查器在 webw
我有一个数组,需要将其从 WebWorker 传输回主线程。据我所知,只有 ArrayBuffers 和 TypedArrays 是可传输的,其他任何内容都是复制而不是传输的。 我遇到的问题是数组包含
我一直在研究如何与网络 worker 之间传输数据,我发现的每个示例都显示以下格式: var myData = new Uint8ClampedArray(256); postMessage(myDa
如何将函数(的副本)从我的主线程发送到我的工作线程? 每当我尝试:worker.postMessage({data, func: (data) => data)时,firefox都会给我一条错误消息:
在 WebWorker 中运行的代码是否在不同的 JavaScript 运行时领域中运行? 最佳答案 是的。 Step 6 in the WHATWG spec . Call the JavaScri
这个问题在这里已经有了答案: How to allow Web Workers to receive new data while it still performing computation?
有没有办法在 JavaScript 中破坏 HTML5 WebWorker? 这是我的情况:我有一个 Web 应用程序生成相当数量的 WebWorker(在 16 到 32 之间的任何地方)来优化一些
我一直致力于优化一些长时间运行的 JavaScript,并尝试实现 WebWorkers。 我有一组独立的任务要计算。在我的初始测试中,有 80 个任务,在主线程上用了 250 毫秒完成。我认为我可以
我正在使用 webworks sdk 开发一个剧本应用程序。 我正在尝试通过发送和接收数据来发出 http 请求(方法:发布)。 我可以从服务器获取响应,但是服务器无法获取 $POST 数据,当我尝试
快速提问 如果我有一个 WebWorker有一个返回 Observable 的函数回到UI代码,如果我再订阅Observable,是在UI线程上运行的observable还是WebWorker线? 我
我正在为 Blackberry Playbook 开发一个 WebWorks 应用程序。他们文档中的这个页面说 You can display a specific type of virtual k
任何人都知道是否可以在 Web Worker 中合并一组立方体几何图形并将其传递回主线程?认为这可以减少合并大量立方体时的延迟。 Three.JS 在 Web Worker 中是否可以正常工作,如果可
我是一名优秀的程序员,十分优秀!