AssimpNetter 6.0.2.1

dotnet add package AssimpNetter --version 6.0.2.1
                    
NuGet\Install-Package AssimpNetter -Version 6.0.2.1
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="AssimpNetter" Version="6.0.2.1" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="AssimpNetter" Version="6.0.2.1" />
                    
Directory.Packages.props
<PackageReference Include="AssimpNetter" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add AssimpNetter --version 6.0.2.1
                    
#r "nuget: AssimpNetter, 6.0.2.1"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package AssimpNetter@6.0.2.1
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=AssimpNetter&version=6.0.2.1
                    
Install as a Cake Addin
#tool nuget:?package=AssimpNetter&version=6.0.2.1
                    
Install as a Cake Tool

alt text

The latest release can be downloaded via NuGet.

Continuous Integration

Introduction

This is a maintained, modern fork of AssimpNet, the cross-platform .NET wrapper for the Open Asset Import Library (otherwise known as Assimp), which is a 3D model import-export library. The primary motivation is for this library to power (offline) content pipelines to import and process 3D models into your game engine's internal format, although the wrapper can be used at runtime to enable your users to import custom content. Please see the Assimp website for a full list of supported formats and features. Each version of the managed wrapper tries to maintain parity with the features of the native version.

P/Invoke is used to communicate with the C-API of the native library. The managed assembly is compiled as AnyCpu and the native binaries are loaded dynamically for either 32 or 64 bit x86, as well as ARM64 applications.

The library is split between two parts, a low level and a high level. The intent is to give as much freedom as possible to the developer to work with the native library from managed code.

Low level

  • Native methods are exposed via the AssimpLibrary singleton.
  • Structures corresponding to unmanaged structures are prefixed with the name Ai and generally contain IntPtrs to the unmanaged data.
  • Located in the Assimp.Unmanaged namespace.

High level

  • Replicates the native library's C++ API, but in a way that is more familiar to C# developers.
  • Marshaling to and from managed memory handled automatically, all you need to worry about is processing your data.
  • Located in the Assimp namespace.

Supported Frameworks

The library supports .NET >= 4.7.2 and .NET Standard 2.1.

Supported Platforms

The NuGet package supports the following Operating Systems and Architectures out of the box (located in the runtimes folder, under RID-specific folders):

  • Windows
    • x86, x64 (Tested on Windows 10), ARM64
  • Linux
    • x64, ARM64 (Tested on Ubuntu 24.04 Noble Numbat)
  • MacOS
    • x64 (Tested on MacOS 13.7 Ventura), ARM64 (Tested on MacOS 14.7 Sonoma)

You may have to build and provide your own native binaries for a target platform that is not listed. If the library does not support a platform you are targeting, please let us know or contribute an implementation! The logic to dynamically load the native library is abstracted, so new platform implementations can easily be added.

All included binaries are built transparently using GitHub Actions on this fork.

Questions & Contributing

All contributions are welcome! Simply raise an issue or open a pull request with your issue/question or contribution!

Unity Users

There existed support for a Unity plugin, however, it is currently in a non-functional state. Pull requests to restore this support would be welcomed!

Licensing

The library is licensed under the MIT license. This means you're free to modify the source and use the library in whatever way you want, as long as you attribute the original authors. The native library is licensed under the 3-Clause BSD license. Please be kind enough to include the licensing text file (it contains both licenses).

More Projects by the Original Author

TeximpNet - A wrapper for the Nvidia Texture Tools and FreeImage libraries.

Tesla Graphics Engine - A 3D rendering engine written in C# and the primary driver for developing AssimpNet.

Product Compatible and additional computed target framework versions.
.NET net5.0 is compatible.  net5.0-windows was computed.  net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed.  net10.0 was computed.  net10.0-android was computed.  net10.0-browser was computed.  net10.0-ios was computed.  net10.0-maccatalyst was computed.  net10.0-macos was computed.  net10.0-tvos was computed.  net10.0-windows was computed. 
.NET Core netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.1 is compatible. 
.NET Framework net472 is compatible.  net48 is compatible.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (2)

Showing the top 2 NuGet packages that depend on AssimpNetter:

Package Downloads
MonoGame.Framework.Content.Pipeline

The Monogame Content Pipeline for Windows, Mac and Linux is used to compile raw content to xnb files.

Bliss

A fast, Cross-platform .NET 9 C# 13 Render Framework.

GitHub repositories (4)

Showing the top 4 popular GitHub repositories that depend on AssimpNetter:

Repository Stars
MonoGame/MonoGame
One framework for creating powerful cross-platform games.
Eremex/controls-demo
MeltyPlayer/MeltyTool
Multitool for viewing/extracting assets from various N64/GCN/3DS/PC games en-masse.
MrScautHD/Bliss
A fast, Cross-platform .NET 9 C# 13 Render Framework.
Version Downloads Last Updated
6.0.2.1 164 10/10/2025
6.0.2 1,881 6/22/2025
5.4.3.4 186 6/22/2025
5.4.3.3 14,029 1/18/2025
5.4.3.2 372 12/31/2024
5.4.3.1 206 12/31/2024
5.4.3 2,281 11/26/2024