Security News
Node.js EOL Versions CVE Dubbed the "Worst CVE of the Year" by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
blender-actions-to-json
Advanced tools
Write the joint data for all `.blend` file actions to a JSON file
Given a Blender
.blend
file, write the joint data for all actions to a JSON file
I export my Blender models to COLLADA using the native Blender COLLADA exporter before parsing these COLLADA files for my model's data.
Unfortunately this only includes the raw keyframes and no metadata about which keyframes belong to which action, so I end up needing to manually keep track of which keyframe each action starts on.
The purpose of this module is to remove that work for me. Now if I want to get the keyframes and joints for the attack
animation, I can just
reference the JSON action file that this module generates under the key attack
.
If the number of keyframes for the attack
action changes, they'll still all be under the attack
action key in the JSON data so
I will still have access to them without needing to manually specify the new range of keyframes. Just iterate over the attack
key
This is part of an effort to automate more of my asset pipeline.
npm install -g blender-actions-to-json
# Save to Blender User Preferences
actions-to-json --install
# Run via CLI
blender /path/to/my-model.blend --background --python `actions2json` -- /path/to/output.json
# Run via bpy.ops
bpy.ops.import_export.actions2json(filepath='/path/to/output.json')
The outputted file will look something like this:
{
"some-action": {
"0.041667": [
[1.0, 0.0, 0.0, 0.0, 0.0, 0.0, -1.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0],
[1.0, 0.0, 0.0, 0.0, 0.0, 0.0, -1.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0],
],
"0.833333": [
[1.0, 0.0, 0.0, 0.0, 0.0, 0.0, -1.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0],
[1.0, 0.0, 0.0, 0.0, 0.0, 0.0, -1.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0]
]
},
"another-action": {
"0": [
[1.0, 0.0, 0.0, 0.0, 0.0, 0.0, -1.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0],
[1.0, 0.0, 0.0, 0.0, 0.0, 0.0, -1.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0],
]
}
}
The file has all of your actions. Each action has all of the keyframe times for that action. Each keyframe time has the pose matrices for each joint in your armature.
The ordering of the joints is the same as bpy.context.selected_pose_bones
. Whatever model exporter
you use probably uses this same order.
For example, COLLADA export files will have your joints in the same order that these actions are, so you can just match them up.
If any of this is confusing please open an issue!
actions2json --help
Usage
$ actions2json
# Returns the filename of the Blender addon. Useful for running the addon via CLI
# i.e.
# blender my-model.blend --python \`actions2json\` -- /var/tmp/output-file.json
$ actions2json --help
# Prints some help text on how to use this command
$ actions2json --install
# Installs and enables the addon and then saves it to your Blender user preferences
# Note that you must have Blender in your $PATH in order for this command to work
Options
-h, --help -> Get help text about using the blender-actions-to-json CLI
-i, --install -> Install the addon and save it in your Blender
blender-actions-to-json
currently only exports actions for one armature.
This script currenly requires that your bpy.context.active_object
is your armature.
blender-actions-to-json
will use the first armature that it finds if the bpy.context.active_object
is not an armature,
so if your file only has one armature you're good to go.
Otherwise you will need either need to select your desired armature before running this script.
You can do this by either:
If you're looking to use this script as part of a fully automated pipeline, #2
is not an option and you will need to do #1.
You can chain blender scripts, so you can run blender my-model.blend --background --python my-script-that-selects-armature --python blender-actions-to-json.py -- ./outputfile.json
Again, all of this only applies if your Blender file has more than one armature. When I eventually work with files with multiple armatures I'll have a better idea of how to address this.
If any of this is confusing please open an issue and I'll try to give a better explanation based on your question(s)!
In order to run the tests you'll need to have blender
in your $PATH so that we can spawn a headless blender process from Node.js.
If Blender isn't already in your $PATH, on mac you can try export PATH="$PATH:/Applications/blender.app/Contents/MacOS"
in your terminal
git clone https://github.com/chinedufn/blender-actions-to-json
cd blender-actions-to-json
npm install
npm run test
-p, --precision
flag to specify the number of decimal places that pose matrices are rounded to. Right now it's set to 6MIT
FAQs
Write the joint data for all `.blend` file actions to a JSON file
The npm package blender-actions-to-json receives a total of 7 weekly downloads. As such, blender-actions-to-json popularity was classified as not popular.
We found that blender-actions-to-json demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.