A Python tool for baking root motion data from PNG sequence frames into JSON format
Project description
Paper2D Root Motion Baker
A Python tool for baking root motion data from PNG sequence frames into JSON format.
Requirements (需求文档)
- This tool is implemented in Python to bake sequential PNG frame data into JSON format. (本工具基于Python实现,用于烘培由连续的序列帧png数据成为Json数据.)
Implementation Principles (实现原理)
- PNG images arranged according to naming rules, with consistent resolution. (按命名规则排列的png图片,分辨率大小一致.)
- The first PNG image is designated as the baseline root motion image. (指认首张png图像为基准root motion图片.)
- Detect a unique marker color point and set its coordinates as the root motion X/Y origin (0, 0). (识别唯一特殊辨识色点,并基于此坐标设定为root motion的X/Y起点(0, 0).)
- Process each image in sequence and calculate X/Y coordinate changes based on the relative point. (按顺序处理各个图片,并基于相对点计算出X/Y坐标变化量.)
- Export a JSON file containing coordinates for each frame. (导出包含每一帧坐标的Json文件.)
Usage Example
python main.py --marker-color 251 242 54 "C:\Users\ocarina\Desktop\Anies\Locomotion" "C:\Users\ocarina\Desktop\Anies\motion_data.json"
Installation
You can install the package via pip:
pip install paper2d-root-motion-baker
Requirements
- Python 3.7+
- Pillow (PIL)
- NumPy
Installation
- Clone this repository
- Install dependencies:
pip install -r requirements.txt
Usage
python main.py <input_directory> <output_json> [--marker-color R G B]
Arguments
input_directory: Directory containing PNG sequence framesoutput_json: Path for the output JSON file--marker-color: RGB values for the marker color (default: 255 0 0 for red)
Example
python main.py ./sprite_sequence output.json --marker-color 255 0 0
Input Requirements
- PNG sequence frames must:
- Be in the same directory
- Have consistent dimensions
- Be named in a sortable sequence
- Each frame must contain exactly one marker point of the specified color
- The first frame is used as the reference frame (0,0)
Output Format
The tool generates a JSON file with the following structure:
{
"frames": [
{
"frame": 0,
"position": {
"x": 0,
"y": 0
}
},
{
"frame": 1,
"position": {
"x": 10,
"y": 5
}
}
// ... more frames
],
"metadata": {
"frame_count": 2,
"version": "1.0"
}
}
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file paper2d_root_motion_baker-0.1.0.tar.gz.
File metadata
- Download URL: paper2d_root_motion_baker-0.1.0.tar.gz
- Upload date:
- Size: 6.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.10.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4934587c4692f6c02bb3ec1da44faf7a79540f6a74c1e59c46d7cf68a773cb29
|
|
| MD5 |
3500dcedd498c16e14cfc7e708dec08d
|
|
| BLAKE2b-256 |
c2bfde9df4198aa68eceb45c8b95dc0d19e09759373863e51e5a116a971aebcf
|
File details
Details for the file paper2d_root_motion_baker-0.1.0-py3-none-any.whl.
File metadata
- Download URL: paper2d_root_motion_baker-0.1.0-py3-none-any.whl
- Upload date:
- Size: 7.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.10.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
34ee7455c4104edcff85c8a043d5d81a1b83e8e6bf827c126b8bcb38f3926773
|
|
| MD5 |
eff0aca5133865f7d8b22ec14ec5bf94
|
|
| BLAKE2b-256 |
d14982e16e9800d58f8d72456b471355de2f97796408b4c6e9ee3793b9d7fe81
|