threejs 创建了10w条THREE.Line,销毁数据,等待了10秒

three + 高德地图,绘制路线,数据量比较大,路由切换时,需要把threejs创建的对象销毁。 简单粗暴的方法,直接卡顿几秒才可以切换,体验极差。

默认销毁代码

ini 复制代码
this.roadGroup.children.forEach(item => {
    this.roadGroup.remove(item);
    item.geometry && item.geometry.dispose();
});

此时卡顿的时候,打印了下children的长度接近10w个,销毁占用时间,阻塞了。

想到不耽误销毁数据,又不影响其他进程,那就异步分批销毁,比如每次销毁300个。这样不一直占用主线程,静默销毁数据,解决。

修改后的代码

ini 复制代码
const destroyRoadGroup = function (callback) {
    if (this.roadGroup) {
        let group = this.roadGroup;

        let index = 0;
        const batchSize = 300; // 每批处理多少个对象
        const delay = 1; // 每批之间延迟时间(ms)

        let children = group.children;
        const disposeBatch = () => {
            const end = Math.min(index + batchSize, children.length);
            for (let i = index; i < end; i++) {
                const obj = children[i];
                if (obj.geometry) {
                    obj.geometry.dispose();
                }
                if (obj.material) {
                    if (Array.isArray(obj.material)) {
                        obj.material.forEach((mat) => mat.dispose());
                    } else {
                        obj.material.dispose();
                    }
                }
            }

            index = end;

            if (index < children.length) {
                setTimeout(disposeBatch, delay); // 下一批
            } else {
                // 所有资源释放完毕
                group.clear(); // 清空 group 内容
                group = null;
                if (callback) callback();
            }
        };

        disposeBatch();
    }
};
相关推荐
今天不要写bug11 分钟前
基于elementUI实现一个可编辑的表格(简洁版)
前端·javascript·elementui
上优14 分钟前
Vue3纯前端同源跨窗口通信移动AGV小车
前端·vue.js·状态模式
h_k1008615 分钟前
Chrome 插件开发入门技术文章大纲
前端·chrome
一只小阿乐15 分钟前
vue-router 的实现原理
前端·javascript·vue.js·路由·vue-router
Zz_waiting.15 分钟前
案例开发 - 日程管理 - 第七期
开发语言·前端·javascript·vue.js·html·路由
一只小风华~19 分钟前
Vue:事件处理机制详解
前端·javascript·vue.js·typescript·前端框架
dy17174 小时前
element-plus表格默认展开有子的数据
前端·javascript·vue.js
2501_915918418 小时前
Web 前端可视化开发工具对比 低代码平台、可视化搭建工具、前端可视化编辑器与在线可视化开发环境的实战分析
前端·低代码·ios·小程序·uni-app·编辑器·iphone
程序员的世界你不懂8 小时前
【Flask】测试平台开发,新增说明书编写和展示功能 第二十三篇
java·前端·数据库
索迪迈科技8 小时前
网络请求库——Axios库深度解析
前端·网络·vue.js·北京百思可瑞教育·百思可瑞教育