assimp/port/PyAssimp
Kim Kulling 3d22d06a2a Merge pull request #1113 from severin-lemaignan/master
[pyassimp] Minor changes (x64 lib path, version number, deps)
2016-12-19 21:38:53 +01:00
..
gen merge severin-lemaignan:for-upstream from github. This is a full rewrite of pyassimp, rendering it much easier to use. 2012-11-09 11:39:34 +00:00
pyassimp [pyassimp] Look as well for the assimp library using std 64bit path 2016-12-15 16:49:44 +00:00
scripts [pyassimp] New version of the pyASSIMP 3D viewer, with much improved 3D controls 2016-12-16 11:02:42 +00:00
README.md Added ability to export scenes with PyAssimp 2016-04-03 13:03:16 +01:00
setup.py [pyassimp] Added missing requirement on numpy to setup.py 2016-12-16 10:33:29 +00:00

README.md

PyAssimp Readme

A simple Python wrapper for Assimp using ctypes to access the library. Requires Python >= 2.6.

Python 3 support is mostly here, but not well tested.

Note that pyassimp is not complete. Many ASSIMP features are missing.

USAGE

To get started with pyAssimp, examine the sample.py script in scripts/, which illustrates the basic usage. All Assimp data structures are wrapped using ctypes. All the data+length fields in Assimp's data structures (such as aiMesh::mNumVertices, aiMesh::mVertices) are replaced by simple python lists, so you can call len() on them to get their respective size and access members using [].

For example, to load a file named 'hello.3ds' and print the first vertex of the first mesh, you would do (proper error handling substituted by assertions ...):


from pyassimp import *
scene = load('hello.3ds')

assert len(scene.meshes)
mesh = scene.meshes[0]

assert len(mesh.vertices)
print(mesh.vertices[0])

# don't forget this one, or you will leak!
release(scene)

Another example to list the 'top nodes' in a scene:


from pyassimp import *
scene = load('hello.3ds')

for c in scene.rootnode.children:
    print(str(c))

release(scene)

INSTALL

Install pyassimp by running:

python setup.py install

PyAssimp requires a assimp dynamic library (DLL on windows, .so on linux :-) in order to work. The default search directories are:

  • the current directory
  • on linux additionally: /usr/lib and /usr/local/lib

To build that library, refer to the Assimp master INSTALL instructions. To look in more places, edit ./pyassimp/helper.py. There's an additional_dirs list waiting for your entries.