a mirror for the AssImp utilities

Kim Kulling 30c4784619 Use constexpr 1 month ago
.github 276d3e998f Bump actions/download-artifact from 5 to 6 (#6382) 2 months ago
cmake-modules 4ad1d2aa30 Fix HUNTER_ERROR_PAGE (#6200) 7 months ago
code 30c4784619 Use constexpr 1 month ago
contrib aadd49311a Fix OOB read in OpenDDLParser::parsePrimitiveDataType (#6315) 4 months ago
doc a815a78433 Updated doc/Preamble.txt & SECURITY.md (#6338) 4 months ago
fuzz 88959b2be7 Fix Whitespace (#6063) 9 months ago
include 1cc7f2ba74 Fix the doxygen documentation from public headers (#6394) 2 months ago
packaging 9f4e7c6d8d Refactoring: use using types (#6266) 5 months ago
port c6f997b584 [PyAssimp] Create `pyproject.toml` (#6378) 2 months ago
samples 88959b2be7 Fix Whitespace (#6063) 9 months ago
scripts dcb89cf107 fix scan_printf script error code handling 2 years ago
test 74a72a20e2 SIB: Fix unittests 2 months ago
tools f544f9c217 Bugfix/fix sonarcube findings (#6369) 3 months ago
.clang-format 88959b2be7 Fix Whitespace (#6063) 9 months ago
.editorconfig 1f28662687 Implemented: Add editor config rules for *.txt files 10 years ago
.gitattributes eb0ace4e18 exclude repository-settings from source-package generated via 'git archive' 8 years ago
.gitignore 69558d8889 Introduce VRML format (.wrl and .x3dv) 3D model support (#5857) 1 year ago
BUILDBINARIES_EXAMPLE.bat efc60076dc udpate build script to fit "Visual Studio 16 2019" Generator 3 years ago
Build.md ea249be466 Made the README more tidy & fix Build.md (#6371) 2 months ago
CHANGES 88959b2be7 Fix Whitespace (#6063) 9 months ago
CMakeLists.txt 4c8a3bd39c [CMake] -l (#6329) 4 months ago
CMakePresets.json 9255412906 Add CMakePreset file (#6295) 5 months ago
CODE_OF_CONDUCT.md c32f4b71b7 Create CODE_OF_CONDUCT.md 2 years ago
CONTRIBUTING.md 5f04cf09e7 Improve the contribution guide 7 years ago
CREDITS 88959b2be7 Fix Whitespace (#6063) 9 months ago
CodeConventions.md 7962897549 Change to what seems to be agreed upon (in line with PR #566) 10 years ago
Dockerfile b447485c06 Fix sonarcube findings (#6242) 6 months ago
INSTALL 88959b2be7 Fix Whitespace (#6063) 9 months ago
LICENSE 441884387f Update LICENSE (#6327) 4 months ago
Readme.md ea249be466 Made the README more tidy & fix Build.md (#6371) 2 months ago
SECURITY.md 3e2e3c9b12 Update contact email for reporting vulnerabilities (#6389) 2 months ago
assimp.pc.in 9fb81c3be6 use GNUInstallDirs where possible 5 years ago

Readme.md

Open Asset Import Library (assimp)

Open Asset Import Library is a library that loads various 3D file formats into a shared, in-memory format. It supports more than 40 file formats for import and a growing selection of file formats for export.

Current project status

Codacy Badge Quality Gate Status Average time to resolve an issue Percentage of issues still open Gurubase Financial Contributors on Open Collective

APIs are provided for C and C++. Various bindings exist to other languages (C#, Java, Python, Delphi, D). Assimp also runs on Android and iOS. Additionally, assimp features various mesh post-processing tools: normals and tangent space generation, triangulation, vertex cache locality optimization, removal of degenerate primitives and duplicate vertices, sorting by primitive type, merging of redundant materials and many more.

Project activity

Alt

Documentation

Read our latest documentation.

Pre-built binaries

Download binaries from our Itch Projectspace.

Test data

Clone our model database for testing purposes.

Communities

Supported file formats

See the complete list of supported formats.

Building

Start by reading our build instructions. We are available in vcpkg, and our build system is CMake; if you used CMake before there is a good chance you know what to do.

Ports

Other tools

Qt5-ModelViewer is a powerful viewer based on Qt5 and Assimp's import and export abilities.
Assimp-Viewer is an experimental implementation for an Asset-Viewer based on ImGUI and Assimp (experimental).

Repository structure

Open Asset Import Library is implemented in C++. The directory structure looks like this:

/code       Source code
/contrib    Third-party libraries
/doc        Documentation (Doxygen source and pre-compiled docs)
/fuzz       Contains the test code for the Google Fuzzer project
/include    Public header C and C++ header files
/scripts    Scripts are used to generate the loading code for some formats
/port       Ports to other languages and scripts to maintain those.
/test       Unit- and regression tests, test suite of models
/tools      Tools (old assimp viewer, command line `assimp`)
/samples    A small number of samples to illustrate possible use cases for Assimp

The source code is organized in the following way:

code/Common                 The base implementation for importers and the infrastructure
code/CApi                   Special implementations which are only used for the C-API
code/Geometry               A collection of geometry tools
code/Material               The material system
code/PBR                    An exporter for physical-based models
code/PostProcessing         The post-processing steps
code/AssetLib/<FormatName>  Implementation for import and export of the format

Contributing

We would greatly appreciate for you to contribute to assimp. The easiest way to get involved is to submit a pull request with your changes against the main repository's master branch.

Contributors

Code Contributors

This project exists thanks to all the people who contribute. [Contribute].

Financial Contributors

Become a financial contributor and help us sustain our community. [Contribute]

Individuals

Organizations

You can support the project with your organization. Your logo will show up here with a link to your website. [Contribute]

License

Our license is based on the modified, 3-clause BSD-License.

An informal summary is: do whatever you want, but include Assimp's license text with your product - and don't sue us if our code doesn't work. Note that, unlike LGPLed code, you may link statically to Assimp. For the legal details, see the LICENSE file.