Jak optimalizovat 3D modely v Python

Jak optimalizovat 3D modely v Python

Problém

Velké soubory 3D modelů mohou být pomalé při načítání a přenosu. Při práci s Aspose.3D v Python existují praktické kroky, které můžete provést ke snížení velikosti souboru a odstranění zbytečných dat scény; především exportem do kompaktního binárního formátu a ořezáním nepoužívaných uzlů ze stromu scény.

Požadavky

  • Python 3.7 nebo novější
  • aspose-3d-foss balíček nainstalován pomocí pip install aspose-3d-foss
  • Vstupní 3D soubor (OBJ, STL, FBX, glTF nebo 3MF)

Optimalizační techniky

Převod do kompaktního binárního formátu

Jedním z nejúčinnějších způsobů, jak snížit velikost souboru, je exportovat scénu do binárního glTF (.glb). Formát GLB balí geometrii a materiály do jediného binárního souboru, který je výrazně menší a rychlejší k načtení než textové formáty jako OBJ nebo ASCII FBX.

from aspose.threed import Scene

scene = Scene.from_file("model.obj")
# Use the .glb extension for binary GLB auto-detection
# Note: FileFormat.GLTF2_BINARY is a None stub — do not pass it to scene.save()
scene.save("model.glb")

Prozkoumejte a spočítejte meshe

Před zpracováním je užitečné pochopit, kolik uzlů meshe scéna obsahuje. To pomáhá identifikovat neočekávaně velké nebo složité scény.

from aspose.threed import Scene
from aspose.threed.entities import Mesh

scene = Scene.from_file("model.obj")

mesh_count = 0
for node in scene.root_node.child_nodes:
    if isinstance(node.entity, Mesh):
        mesh_count += 1
        print(f"  Mesh '{node.name}': {len(node.entity.control_points)} vertices, "
              f"{node.entity.polygon_count} polygons")

print(f"Total meshes: {mesh_count}")

Odstraňte nepoužívané (vyloučené) uzly

Uzly označené jako vyloučené nejsou vykreslovány. Identifikace a přeskočení těchto uzlů během exportu snižuje velikost scény. The excluded atribut je vlastnost na Entity, není volání metody.

from aspose.threed import Scene
from aspose.threed.entities import Mesh

scene = Scene.from_file("model.obj")

active_nodes = []
for node in scene.root_node.child_nodes:
    entity = node.entity
    if entity is not None and not entity.excluded:
        active_nodes.append(node.name)

print(f"Active (non-excluded) nodes: {active_nodes}")

Příklad kódu

Tento příklad načte scénu, vypíše statistiky meshe a uloží do kompaktního formátu GLB: hlavní praktická optimalizace dostupná prostřednictvím Aspose.3D.

from aspose.threed import Scene
from aspose.threed.entities import Mesh

# Load the input model
scene = Scene.from_file("input.obj")

# Inspect mesh count and vertex totals
total_vertices = 0
for node in scene.root_node.child_nodes:
    if isinstance(node.entity, Mesh):
        mesh = node.entity
        total_vertices += len(mesh.control_points)

print(f"Total vertices before export: {total_vertices}")

# Save to compact binary GLB — use .glb extension for auto-detection
# Note: FileFormat.GLTF2_BINARY is a None stub and must not be passed to scene.save()
scene.save("output.glb")
print("Saved as GLB (binary glTF)")

Poznámky k rozsahu optimalizace

Aspose.3D neposkytuje algoritmy pro decimaci meshe nebo redukci polygonů. Snížení velikosti souboru se dosahuje především pomocí:

  • Export do binárních formátů (GLB místo OBJ nebo ASCII FBX)
  • Přeskočení vyloučených nebo prázdných uzlů během vaší vlastní logiky zpracování

Tvrzení o konkrétních procentech zrychlení nebo úsporách paměti závisí na vašich vstupních datech a nelze je obecně zaručit.

Viz také

 Čeština