A tool for converting ROS 2 image topics in rosbag2 MCAP files to MP4 videos
Project description
mcap-to-mp4
A tool for converting ROS 2 image topics recorded in rosbag2 MCAP files into MP4 videos
English
This tool provides a simple way to convert ROS 2 image topics recorded in rosbag2 MCAP files into standard MP4 video files.
It is especially useful for visualizing and sharing regularly published image streams, such as camera feeds.
By default, the tool assumes that input messages are recorded at a roughly fixed rate, and generates an MP4 using the average frame interval of the input messages (CFR: Constant Frame Rate).
When needed, --timestamp-timing enables sensor_msgs/Image.header.stamp-based timing (VFR: Variable Frame Rate).
As a result, the generated videos are well suited for experiment reviews, demos, and presentations.
日本語
このツールは、rosbag2 の MCAP ファイルに記録された ROS 2 の画像トピックを、標準的な MP4 動画ファイルに変換します。
カメラ映像のように、一定周期で発行される画像ストリームの可視化や共有に特に便利です。
デフォルトでは入力メッセージがおおむね一定周期で記録されていることを前提とし、生成される MP4 は入力メッセージ間の平均フレーム間隔(CFR: Constant Frame Rate / 固定フレームレート)を用いて出力します。
--timestamp-timing を指定すると sensor_msgs/Image.header.stamp を使った可変フレームレート(VFR: Variable Frame Rate / 可変フレームレート)で出力します。
そのため、実験の振り返りやデモ、プレゼンテーションに適しています。
Requirements
Note: This tool does NOT require a ROS 2 runtime environment.
You only need Python and the following dependencies:
- Python3
- mcap
- mcap-ros2-support
- pillow
- numpy
- imageio
- ffmpeg
QuickStart
pip
# Install
pip install mcap-to-mp4
# Run
mcap-to-mp4 $path_to_the_mcap_file -t $topic_name -o $outputfilename
uv
# Install
uv tool install mcap-to-mp4
# Run
mcap-to-mp4 $path_to_the_mcap_file -t $topic_name -o $outputfilename
Docker
# Build
git clone https://github.com/Tiryoh/mcap-to-mp4.git
docker build -t tiryoh/mcap-to-mp4 .
# Run
docker run --rm -it -v "${PWD}:/works" tiryoh/mcap-to-mp4 $path_to_the_mcap_file -t $topic_name -o $outputfilename
Usage
pip
Install the package from PyPI
pip install mcap-to-mp4
Install the package from source (optional)
# optional
git clone https://github.com/Tiryoh/mcap-to-mp4.git
cd mcap-to-mp4
pip install -e .
mcap-to-mp4 --help
uv
Install the package from PyPI
uv tool install mcap-to-mp4
Install the package from source (optional)
# optional
git clone https://github.com/Tiryoh/mcap-to-mp4.git
cd mcap-to-mp4
uv sync --group dev
# Run with uv run
uv run mcap-to-mp4 --help
Download sample mcap rosbag2 file
wget "https://drive.usercontent.google.com/download?id=1TxKxq-SN_9ryiFxH6kQG07Gy90_bpnWW&confirm=xxx" -O "realsense_rosbag2.zip"
unzip realsense_rosbag2.zip
Run
# With pip or uv tool install:
mcap-to-mp4 ./rosbag2_2024_02_18-23_35_48/rosbag2_2024_02_18-23_35_48_0.mcap -t /camera/color/image_raw -o output.mp4
# With uv sync (source install):
uv run mcap-to-mp4 ./rosbag2_2024_02_18-23_35_48/rosbag2_2024_02_18-23_35_48_0.mcap -t /camera/color/image_raw -o output.mp4
# Optional: use header.stamp based VFR timing
mcap-to-mp4 ./rosbag2_2024_02_18-23_35_48/rosbag2_2024_02_18-23_35_48_0.mcap -t /camera/color/image_raw -o output_vfr.mp4 --timestamp-timing
Docker
Install the package
git clone https://github.com/Tiryoh/mcap-to-mp4.git
docker build -t tiryoh/mcap-to-mp4 .
Download sample mcap rosbag2 file
wget "https://drive.usercontent.google.com/download?id=1TxKxq-SN_9ryiFxH6kQG07Gy90_bpnWW&confirm=xxx" -O "realsense_rosbag2.zip"
unzip realsense_rosbag2.zip
Run
docker run --rm -it -v "${PWD}:/works" tiryoh/mcap-to-mp4 ./rosbag2_2024_02_18-23_35_48/rosbag2_2024_02_18-23_35_48_0.mcap -t /camera/color/image_raw -o output.mp4
# Optional: use header.stamp based VFR timing
docker run --rm -it -v "${PWD}:/works" tiryoh/mcap-to-mp4 ./rosbag2_2024_02_18-23_35_48/rosbag2_2024_02_18-23_35_48_0.mcap -t /camera/color/image_raw -o output_vfr.mp4 --timestamp-timing
Notes
--timestamp-timingoption: This option saves each frame as a PNG file to a temporary directory before encoding with ffmpeg, which takes significantly longer than the default CFR mode. For example, a 6868-frame rosbag took about 4 minutes in CFR mode vs. about 11 minutes in VFR mode (measured on M3 MacBook Air).- Memory check: During conversion, the tool estimates memory usage and displays it.
- Linux (including WSL): Estimated memory usage is displayed. If available system memory is low, a warning is shown and you will be prompted to continue or abort.
- macOS: Estimated memory usage is displayed. Available memory check is not supported.
- Windows (non-WSL): Memory check is not supported.
License
Copyright 2024-2026 Daisuke Sato
This repository is licensed under the MIT license, see LICENSE.
Unless attributed otherwise, everything in this repository is under the MIT license.
Related Projects
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 mcap_to_mp4-0.5.0.tar.gz.
File metadata
- Download URL: mcap_to_mp4-0.5.0.tar.gz
- Upload date:
- Size: 80.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
78b1c79b707f6c586ab09302d79ecdb3ccbb9acaca18e58b733c3642c693c386
|
|
| MD5 |
4be2e07d6e6a72545ff0d4ec5af8fcee
|
|
| BLAKE2b-256 |
a4a8c8d85571d15380b8a080506654649ba039a672ffea18fd0de6c7bcf6af4f
|
File details
Details for the file mcap_to_mp4-0.5.0-py3-none-any.whl.
File metadata
- Download URL: mcap_to_mp4-0.5.0-py3-none-any.whl
- Upload date:
- Size: 9.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9075eb6742792088360d191c3bf527f5493bc1601c2b69b9036ea2c7d8027c30
|
|
| MD5 |
a7158f57de6cc1c37f7e72f5102ad7da
|
|
| BLAKE2b-256 |
981a1ce6a70acfd5c3cd2c0abc46a7be7b8423bd7017066d42c1e5302c4c2804
|