javascript - 如何正确处理 Three.js 场景? (r55)

标签 javascript memory-leaks three.js

似乎 Three.js 没有一个很好的方法来处理 THREE.Scene 和该场景中的所有对象。

目前我正在做以下事情:

  $.each(scene.__objects, function(idx, obj) {                               
    scene.remove(obj);                                                                                     
    if (obj.geometry) {                                                                                    
      obj.geometry.dispose();                                                                              
    }                                                                                                      
    if (obj.material) {                                                                                    
      if (obj.material instanceof THREE.MeshFaceMaterial) {                 
        $.each(obj.material.materials, function(idx, obj) {                 
          obj.dispose();                                                                                   
        });                                                                                                
      } else {                                                                                             
        obj.material.dispose();                                                                            
      }                                                                                                    
    }                                                                                                      
    if (obj.dispose) {                                                                                     
      obj.dispose();                                                                                       
    }                                                                                                      
  });             

查看 Chrome 堆分析器,仍有许多对象没有被清理(纹理、着色器 Material 、矢量等...)。

最佳答案

我同意 arriu 的观点,three.js 中应该有一种更简洁和通用的内存处理方式,可能从场景节点开始,一直向下遍历。我还认为应该扩展他上面的泛型函数,以处理更多类型的内存分配。

  • 查看示例 webgl_test_memory.html,它做了一些非常针对该示例的事情,并在分配后立即释放内存。
  • 查看 webgl_test_memory2.html,此示例还做了一些非常具体的事情,它向数组添加网格,然后遍历并处理数组的元素。此方法无法处理在函数调用中进行的许多内存分配。

我并不是说这两个例子没有释放内存。我认为场景节点应该有一个方法来释放它下面的所有内存。

关于javascript - 如何正确处理 Three.js 场景? (r55),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14530405/

相关文章:

javascript - 在 THREE.js 中的多个 Line 对象上使用 GeometryUtils.merge

javascript - 有什么方法可以防止在单例实例中覆盖/覆盖函数/变量?

javascript - 如何在javascript中对小数进行四舍五入和求和?

javascript - 单击“阅读更多”按钮时每个帖子的 WordPress 模式

memory-management - 此代码C++ OpenCV中的内存泄漏在哪里?

javascript - Threejs 更改网格颜色无法被识别

javascript - 我如何开始学习 Ext Js ?我首先可以做什么?

java - Java Enterprise 应用程序中的类加载问题

c - 调试内存泄漏

three.js - ThreeJS InstancedBufferGeometry 剔除问题?