doc:appunti:linux:video:olive_editor_ovexml
Differences
This shows you the differences between two versions of the page.
Next revision | Previous revision | ||
doc:appunti:linux:video:olive_editor_ovexml [2023/09/28 14:59] – created niccolo | doc:appunti:linux:video:olive_editor_ovexml [2023/09/28 18:03] (current) – [Proof of concept program] niccolo | ||
---|---|---|---|
Line 1: | Line 1: | ||
- | ====== Olive Video Editor OVEXML file format ====== | + | ====== Olive Video Editor: an insight of the OVEXML file format ====== |
**[[https:// | **[[https:// | ||
+ | |||
+ | ===== The project can be saved as an XML file ===== | ||
A feature that I really apreciated is the ability to save the project file into an XML file (with the **.ovexml** extension). Being addicted to the **GNU/Linux command** line and **ffmpeg** I immediately tried to convert an Olive project into an ffmpeg script. | A feature that I really apreciated is the ability to save the project file into an XML file (with the **.ovexml** extension). Being addicted to the **GNU/Linux command** line and **ffmpeg** I immediately tried to convert an Olive project into an ffmpeg script. | ||
+ | |||
+ | ===== A walk inside the OVEXML ===== | ||
+ | |||
+ | Here I explain some findings on an **OVEXML** file created with **Olive v.0.2**. | ||
Beware that the project I worked on is a **really simple** one! Only two tracks (one video and one audio), video is always locked with the audio, **the clips are just concatenated** without transition effects, gaps, etc. Parsing the OVEXML of such a project is feasible, any extra feature could make the job too challenging. | Beware that the project I worked on is a **really simple** one! Only two tracks (one video and one audio), video is always locked with the audio, **the clips are just concatenated** without transition effects, gaps, etc. Parsing the OVEXML of such a project is feasible, any extra feature could make the job too challenging. | ||
- | My goal was to build **the sequence of clips** used into a project, | + | My goal was to print **the sequence of clips** used into a project, |
- | The first challenge was to find the link from the top level node of the project (the **org.olivevideoeditor.Olive.sequence**) down to the lower level node **org.olivevideoeditor.Olive.footage** (e.g. the media files on the computer disk). In this walk I had to figure out how to get the clip starting frame and its length. | + | The first challenge was to find the link from the top level node of the project (the **org.olivevideoeditor.Olive.sequence**) down to the lower level nodes **org.olivevideoeditor.Olive.footage** (e.g. the media files on the computer disk). In this walk I had to figure out how to get the clip starting frame and its length. |
The nodes to walk into the XML structure are the following: | The nodes to walk into the XML structure are the following: | ||
Line 29: | Line 35: | ||
</ | </ | ||
- | When foolowing | + | When following |
<code xml> | <code xml> | ||
Line 49: | Line 55: | ||
</ | </ | ||
- | As you can see the frame numbers are represented as rationales. Being my framerate | + | As you can see the frame numbers are represented as rational numbers. Being my footages shot at 29.97 FPS (i.e. 30000/1001) the math is as follow: **1001 / 200 * 30000 / 1001 = 150** (i.e. 150 frames clip length). |
+ | |||
+ | The most challenging part was to understand how the clips are ordered into the timeline. Unfortunately the **%%< | ||
+ | |||
+ | We have instead to look at the **%%< | ||
+ | |||
+ | <code xml> | ||
+ | <node version=" | ||
+ | <input id=" | ||
+ | < | ||
+ | < | ||
+ | < | ||
+ | </ | ||
+ | </ | ||
+ | </ | ||
+ | </ | ||
+ | |||
+ | The ASCII string **%%AwAAAAgAAAAFAAAABwAAAAYAAAA=%%** is actually a base64 encoded binary string that you can decode on the command line into a binary file: | ||
+ | |||
+ | <code bash> | ||
+ | echo ' | ||
+ | </ | ||
+ | |||
+ | And then open it with an hex editor: | ||
+ | |||
+ | < | ||
+ | 03 00 00 00 │ 08 00 00 00 │ 05 00 00 00 │ 07 00 00 00 │ 06 00 00 00 | ||
+ | </ | ||
+ | |||
+ | Hence the timeline sequence of clip elements: #3, #8, #5, #7 and #6 (32 bit unsigned integers, little endian). | ||
+ | |||
+ | ===== Proof of concept program ===== | ||
+ | |||
+ | Here you can find my Python script that I used to parse an Olive Editor project file, the output is the ordered list of all the clips used, with the **footage filename**, the **start frame** and the **length** of the clip (in frames). | ||
+ | |||
+ | **{{.: | ||
doc/appunti/linux/video/olive_editor_ovexml.1695905996.txt.gz · Last modified: 2023/09/28 14:59 by niccolo