This repository provides Python3 scripts for manipulating and converting BVH motion capture files.
- This package depends on a bleeding edge version of the bvh module, that has not been pushed to pypi.org yet.
Therefore, you need to install this package using a direkt URL link for now. - Make sure to have pip >= 18.1 installed for supporting PEP 508 URL dependencies.
- On Linux/MacOS:
pip install --upgrade pip
- On Windows use
python -m pip install --upgrade pip
- On Linux/MacOS:
- To install using development mode:
pip install -e git+https://github.com/OlafHaag/bvh-toolbox.git@master#egg=bvhtoolbox
- To install using regular mode (building the package):
pip install https://github.com/OlafHaag/bvh-toolbox/archive/master.zip
- The installation creates some console scripts you can use.
- Command: bvhrenamejoints
- Command: bvhremoveframes
- Command: bvhoffsetjointangles
- Can be used to additively offset joint angles in the BVH by supplying a csv table containing the mapping of joint names to euler angles.
- The angles must be in the same order as the joint's channels in the BVH hierarchy.
- Command: bvh2xsf
- Command: bvh2xaf
- Converts BVH files to the Cal3D XML skeleton (XSF) and animation (XAF) file formats.
- The XAF files rely on the respective skeleton file.
- XAF files have been tested to work with skeletons that were exported from 3DS Max and Blender.
- I use the resulting xaf files in Worldviz' Vizard, so it's only been tested in this context.
- Command: bvh2egg
- Converts BVH files to the Panda3D animation file egg format.
- Command: bvh2csv
- Converts BVH to comma separated values tables.
- Ouputs one file for hierarchy, one for joint rotations, and one for joint world positions.
- Use
--hierarchy
to export the respective CSV file. - Using only the
--rotation
or the--position
flag you can output only one of the transform tables. - The
--out
parameter only takes a directory path as an argument. - With the
--ends
flag the End Sites are included in the *_pos.csv file.
- Command: csv2bvh
- Takes 3 CSV files (hierarchy, rotation, position) previously exported using bvh2csv or created otherwise and builds a bvh file from them.
All converters have a --scale
parameter taking a float as an argument. You can use it to convert between units for the position and offset values.
- Open terminal.
- If you've installed the bvhtoolbox into a conda/virtual environment, you have to activate it first.
- type
<script_name> -h
(substitute <script_name> by one of the commands above) to get more information on the usage.