Jak optimalizovat 3D modely v TypeScriptu

Jak optimalizovat 3D modely v TypeScriptu

Aspose.3D FOSS pro TypeScript poskytuje několik strategií pro snížení velikosti výstupního souboru a zlepšení propustnosti zpracování. Tento průvodce pokrývá výběr formátu, binární vkládání, pipeline v paměti a optimalizace na úrovni Node.js.

Průvodce krok za krokem

Krok 1: Vyberte správný výstupní formát

GLB (binární glTF) produkuje nejkompaktnější výstup s dobrým podporou nástrojů. OBJ je textově založený a větší. STL je kompaktní pro workflow pouze s geometrií.

FormátVelikostObsahuje materiályObsahuje animaciNejlepší použití
GLBMalýAno (vložené)AnoWeb, hry, obecná výměna
glTFStředníAno (samostatně)AnoVývoj, inspekce
STLMalýNeNe3D printing, geometry-only
OBJVelkýOddělit .mtlNeZastaralé nástroje, široká kompatibilita
FBXStředníNe*Ne*Importér/exportér existuje, ale není propojen s automatickým rozpoznáváním
3MFMalýAnoNeModerní 3D tisk

Krok 2: Exportujte do binárního GLB

Při ukládání do GLB nastavte GltfSaveOptions.binaryMode = true aby vznikl jediný samostatný binární soubor. Tím se vyhnete samostatnému .bin doprovodnému souboru a je vyžadováno pro mnoho 3D prohlížečů:

import { Scene } from '@aspose/3d';
import { ObjLoadOptions } from '@aspose/3d/formats/obj';
import { GltfSaveOptions } from '@aspose/3d/formats/gltf';

const scene = new Scene();
scene.open('complex-model.obj', new ObjLoadOptions());

const opts = new GltfSaveOptions();
opts.binaryMode = true;

scene.save('optimized.glb', opts);
console.log('Saved compact binary GLB');

Krok 3: Použijte Buffer I/O pro pipeline v paměti

Při zpracování souborů ve webové službě použijte openFromBuffer a saveToBuffer aby se předešlo zápisu do souborového systému:

import { Scene } from '@aspose/3d';
import { ObjLoadOptions } from '@aspose/3d/formats/obj';

function convertInMemory(inputBuffer: Buffer): Buffer {
    const scene = new Scene();
    scene.openFromBuffer(inputBuffer, new ObjLoadOptions());
    return scene.saveToBuffer('glb');
}

Krok 4: Hromadně zpracovávejte soubory pomocí pracovních vláken

Pro velké konverzní úlohy rozdělte práci mezi pracovní vlákna Node.js, abyste využili více jader CPU:

// worker.ts
import { workerData, parentPort } from 'worker_threads';
import { Scene } from '@aspose/3d';
import { ObjLoadOptions } from '@aspose/3d/formats/obj';

const { inputPath, outputPath } = workerData;

const scene = new Scene();
scene.open(inputPath, new ObjLoadOptions());
scene.save(outputPath);

parentPort?.postMessage({ done: true, output: outputPath });
// main.ts: dispatch files to workers
import { Worker } from 'worker_threads';
import * as fs from 'fs';
import * as path from 'path';

const files = fs.readdirSync('./input').filter(f => f.endsWith('.obj'));

for (const file of files) {
    const inputPath = path.join('./input', file);
    const outputPath = path.join('./output', file.replace('.obj', '.glb'));

    const worker = new Worker('./dist/worker.js', {
        workerData: { inputPath, outputPath }
    });

    worker.on('message', msg => console.log(`Converted: ${msg.output}`));
    worker.on('error', err => console.error(`Error: ${err}`));
}

Krok 5: Sledujte paměť pro velké modely

U souborů nad 50 MB sledujte využití haldy a pokud je paměť omezená, zpracovávejte soubory sekvenčně:

function logMemory(label: string) {
    const used = process.memoryUsage();
    console.log(`[${label}] heapUsed: ${Math.round(used.heapUsed / 1024 / 1024)} MB`);
}

logMemory('before load');
const scene = new Scene();
scene.open('large-model.obj');
logMemory('after load');
scene.save('output.glb');
logMemory('after save');

Zvyšte haldu Node.js pro velmi velké modely:

node --max-old-space-size=8192 convert.js

Často kladené otázky

Jaký je nejkompaktnější výstupní formát?

GLB (binární glTF) s vloženými prostředky produkuje nejkompaktnější jednosouborový výstup pro scény s materiály a texturami. STL je kompaktnější pro obsah pouze s geometrií.

Používá @aspose/3d zjednodušení meshe nebo LOD?

Ne. Knihovna čte a zapisuje zdrojovou geometrii, aniž by měnila topologii meshe. Zjednodušení meshe (redukování vrcholů, generování LOD) není podporováno.

Mohu odstranit materiály, aby se snížila velikost souboru?

Nastavte ObjSaveOptions.enableMaterials = false při ukládání do OBJ. Pro glTF jsou všechna materiálová data vždy zahrnuta; použijte STL pro výstup pouze s geometrií.


Viz také

 Čeština