HTML JPG PDF XML 3MF
Aspose.3D  for .NET
3MF

通過 C# 從 3MF 提取資產

構建您自己的 .NET 應用以使用服務器端 API 從 3MF 文件中提取資產。

如何使用 C# 從 3MF 文件中提取資產

為了從 3MF 文件中提取資產,我們將使用

Aspose.3D for .NET

API 是一個功能豐富、功能強大且易於使用的 API for C# 平台,可與提取資產一起使用。打開

NuGet

包管理器,搜索 Aspose.3D 並安裝。您也可以從包管理器控制台使用以下命令。

包管理器控制台命令


PM> Install-Package Aspose.3D

通過 C# 從 3MF 提取資產的步驟

Aspose.3D 使開發人員只需幾行代碼即可輕鬆地從 3MF 文件中提取資產。

  • 通過 Scene 類的構造函數加載 3MF 文件- 創建 zip 文件格式對像作為輸出文件格式- 創建歸檔類並處理提取資產類- 調用 Extract 方法並保存文件

系統要求

Aspose.3D for .NET 在所有主要操作系統上都受支持。只需確保您具有以下先決條件。

  • Microsoft Windows 或具有 .NET Framework、.NET Core、Mono 的兼容操作系統- Microsoft Visual Studio 等開發環境- Aspose.3D for .NET 在您的項目中引用
 

C# 代碼從 3MF 中提取資產


//需要提取資產的源文件
string file = "template.3mf";
Scene scene = new Scene(file);  

//輸出為壓縮文件格式,Directory 表示現有文件夾的名稱
var zipOutput = Path.Combine("Directory", "OutputFile.zip");
using var output = new FileStream(zipOutput, FileMode.Create);
using var za = new Zip(output);

//調用 Extract 方法執行資產提取操作
Extract(scene,za,true);

//可調用Extract方法,參數texture表示:是否提取紋理
private void Extract(Scene scene, Zip za,bool texture)
{
    var extractor = new Extractor(za,texture);
    extractor.Extract(scene);
}

//創建壓縮文件處理類
class Zip : IDisposable
{
    private ZipArchive archive;
    private HashSet<string> entries = new HashSet<string>();

    public Zip(Stream stream)
    {
        archive = new ZipArchive(stream, ZipArchiveMode.Create);
    }
    public void Dispose()
    {
        archive.Dispose();
    }

    public void Add(string fileName, byte[] content, bool enableCompression)
    {
        var entryName = PickName(fileName);
        var compressionLevel = enableCompression ? CompressionLevel.Fastest : CompressionLevel.NoCompression;
        var entry = archive.CreateEntry(entryName, compressionLevel);
        using var stream = entry.Open();
        stream.Write(content, 0, content.Length);
    }
    
    private string PickName(string fileName)
    {
        if (!entries.Contains(fileName))
        {
            entries.Add(fileName);
            return fileName;
        }
        var baseName = Path.GetFileNameWithoutExtension(fileName);
        var ext = Path.GetExtension(fileName);
        for (var idx = 2; ; idx++)
        {
            var newName = baseName + "_" + idx;
            if (!string.IsNullOrEmpty(ext))
                newName += ext;
            if (entries.Contains(newName))
                continue;
            entries.Add(newName);
            return newName;
        }
    }
}

//創建資產提取處理類
class Extractor
{
    private Zip zip;
    private bool texture;
    HashSet<A3DObject> visited = new HashSet<A3DObject>();
    public Extractor(Zip zip,bool texture)
    {
        this.zip = zip;
        this.texture = texture;
    }

    private bool CanVisit(A3DObject obj)
    {
        if (visited.Contains(obj))
            return false;
        visited.Add(obj);
        return true;
    }
    public void Extract(Scene scene)
    {
        if (scene.Library != null && scene.Library.Count > 0)
        {
            foreach (var obj in scene.Library)
            {
                Visit(obj);
            }
        }
        VisitNode(scene.RootNode);
    }
    private void VisitNode(Node node)
    {
        if (!CanVisit(node))
            return;
        if (texture)
        {
            foreach (var mat in node.Materials)
            {
                VisitMaterial(mat);
            }
        }

        foreach (var entity in node.Entities)
        {
            if (entity is Mesh)
                Save((Mesh)entity, node.Name);
        }
        
        foreach (var child in node.ChildNodes)
        {
            VisitNode(child);
        }
    }
    private void VisitMaterial(Material mat)
    {
        if (!CanVisit(mat))
            return;
        if (!texture)
            return;
        foreach (var tslot in mat)
        {
            if (tslot.Texture is Texture)
            {
                Save((Texture)tslot.Texture);
            }
        }
    }
    private void Visit(A3DObject obj)
    {
        if (texture && obj is Texture)
        {
            Save((Texture)obj);
        }
        else if (obj is Mesh)
        {
            Save((Mesh)obj, null);
        }
        else if (obj is Node)
        {
            VisitNode((Node)obj);
        }
    }
    private void Save(Mesh mesh, string? nodeName)
    {
        if (!CanVisit(mesh))
            return;
        Scene scene = new Scene(mesh);
        using (var ms = new MemoryStream())
        {
            scene.Save(ms, FileFormat.FBX7400ASCII);
            var name = nodeName;
            if (string.IsNullOrEmpty(name))
                name = mesh.Name;
            if (string.IsNullOrEmpty(name))
                name = "mesh";
            var ext = ".fbx";
            zip.Add(name + ext, ms.ToArray(), true);
        }
    }
    private void Save(Texture tex)
    {
        if (tex.Content == null || !CanVisit(tex))
            return;
        var fileName = tex.FileName != null ? Path.GetFileName(tex.FileName) : null;
        zip.Add(fileName, tex.Content, false);
    }
}
 
  • 關於Aspose.3D for .NET API

    Aspose.3D 是用於加載、修改和轉換 3D 文件的 CAD 和遊戲軟件 API。 API 是獨立的,不需要任何 3D 建模或渲染軟件。可以輕鬆地將 API 用於 Discreet3DS、WavefrontOBJ、STL(ASCII,二進制)、Universal3D、FBX(ASCII,二進制)、Collada、glTF、PLY、 GLB、DirectX 和更多格式。

    從 3MF 中提取資產的免費應用程序

    查看我們的現場演示 提取器 3MF 具有以下好處。

      無需下載或設置任何東西
      無需編寫或編譯代碼
      只需上傳 3MF 文件並點擊“提取”按鈕
      如果需要,從鏈接下載 3MF 文件

    3MF 什麼是 3MF 文件格式

    3MF,3D 製造格式,應用程序使用它來將 3D 對像模型呈現給各種其他應用程序、平台、服務和打印機。它旨在避免其他 3D 文件格式(如 STL)中的限制和問題,以便與最新版本的 3D 打印機一起使用。 3MF 是一種相對較新的文件格式,由 3MF 聯盟開發和發布。

    閱讀更多

    其他支持從格式中提取資產的應用程序

    使用 C#,One 還可以從許多其他文件格式中提取資產,包括。

    3DS (3D Studio 網格文件格式)
    AMF (增材製造形式)
    ASE (二維動畫文件)
    DAE (數字資產交易所)
    DXF (繪圖交換格式)
    DRC (Google Draco)
    FBX (3D 格式)
    GLB (3D 文件二進製表示)
    GLTF (GL 傳輸格式)
    JT (木星鑲嵌文件)
    OBJ (3D 文件格式)
    PLY (多邊形文件格式)
    PDF (3D PDF)
    RVM (AVEVA 工廠設計模型)
    STL (可互換的 3D 表面幾何形狀)
    U3D (Universal 3D)
    VRML (虛擬現實建模語言)
    X (DirectX 模型圖像)
    USD (通用場景描述)
    USDZ (通用場景描述 Zip 存檔)