Skip to main content

GUI for PyVideoKit — FFmpeg-based video processing

Project description

🎬 PyVideoKit-GUI

Python License

Graphical interface for PyVideoKit — FFmpeg-based video processing. Provides the same operations as PyVideoKit-CLI through a PySide6 desktop application with real-time progress tracking, drag-and-drop input, and batch processing.


✨ Features

  • 🎞️ Convert to FFV1 — batch-convert multiple videos to lossless FFV1/MKV masters
  • ✂️ Trim — cut a segment by start/end time with stream copy (no re-encoding)
  • 🔗 Concatenate — join multiple videos with drag-and-drop reordering and multi-selection
  • 🎬 Fade — fade-in and/or fade-out on an FFV1 master
  • 📼 VHS effect — batch-apply retro visual noise, color bleed, and audio degradation
  • 🔊 Extract audio — batch-export audio tracks to uncompressed WAV (PCM 16-bit)
  • 📺 Prepare for YouTube — batch-encode to ProRes 422 HQ MOV, upscaled to 4K
  • 🖱️ Drag & drop — drop files anywhere on any panel; drop multiple files onto batch panels
  • 📁 Output directory — optionally redirect all batch output to a chosen folder

📦 Requirements

  • Python ≥ 3.10
  • PySide6 ≥ 6.0
  • FFmpeg and FFprobe available in PATH
  • SoX available in PATH (required by VHS effect)
  • PyVideoKit-Libs — installed automatically as a dependency
  • paplay, pw-play, or ffplay in PATH (optional — for completion sound)

🔧 Installation

🏗️ Arch Linux (AUR)

yay -S python-pyvideokit-gui

FFmpeg, FFprobe, SoX, PySide6, and PyVideoKit-Libs are installed automatically as pacman dependencies.

🐍 Other systems (pip)

pip install PyVideoKit-GUI

Make sure FFmpeg, FFprobe, and SoX are available in your PATH.


🖥️ Desktop Integration

Arch Linux users get the launcher entry and icon automatically via the AUR package. For all other systems, create them manually:

1. Save the icon:

mkdir -p ~/.local/share/icons/hicolor/scalable/apps
cat > ~/.local/share/icons/hicolor/scalable/apps/pvk-gui.svg << 'EOF'
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 48 48">
  <rect x="4" y="14" width="40" height="30" rx="3" fill="#2d3561"/>
  <rect x="10" y="19" width="28" height="20" rx="2" fill="#1a2038"/>
  <polygon points="18,21 18,37 33,29" fill="#ff6b6b"/>
  <rect x="4" y="6" width="40" height="8" rx="2" fill="#ff6b6b"/>
  <rect x="11" y="6" width="6" height="8" fill="#ffffff"/>
  <rect x="23" y="6" width="6" height="8" fill="#ffffff"/>
  <rect x="35" y="6" width="5" height="8" fill="#ffffff"/>
</svg>
EOF

2. Create the .desktop entry:

mkdir -p ~/.local/share/applications
cat > ~/.local/share/applications/pvk-gui.desktop << 'EOF'
[Desktop Entry]
Version=1.0
Type=Application
Name=PyVideoKit
GenericName=Video Processing Tool
Comment=FFmpeg-based video processing GUI
Exec=pvk-gui
Icon=pvk-gui
Categories=AudioVideo;Video;AudioVideoEditing;
Terminal=false
Keywords=video;ffmpeg;trim;fade;vhs;youtube;convert;
EOF

3. Refresh the icon cache (maybe required in some desktop environments):

gtk-update-icon-cache ~/.local/share/icons/hicolor/

PyVideoKit will now appear in your application launcher.


🚀 Usage

pvk-gui

The application opens a tabbed window. Each tab corresponds to one operation:

Tab Operation Batch
🎞️ Convert to FFV1 Convert videos to lossless FFV1/MKV masters
✂️ Trim Cut a segment by start/end time (no re-encoding)
🔗 Concat Join multiple videos (drag to reorder, multi-select to remove)
🎬 Fade Add fade-in and/or fade-out
📼 VHS Effect Apply retro VHS visual and audio effect
🔊 Extract Audio Export audio tracks to WAV
📺 YouTube Encode to ProRes 422 HQ MOV for upload

Batch panels accept multiple input files via drag & drop or the "Add files…" button, and optionally redirect output to a chosen directory. They show two progress bars: one for the current file and one for the overall batch.

All operations run in a background thread. A system sound plays on completion.


🔄 Typical Workflow

🎞️ Convert to FFV1  →  ✂️ Trim / 🎬 Fade / 📼 VHS Effect  →  📺 YouTube

Operations that re-encode (Fade, VHS Effect, YouTube) expect an FFV1 .mkv as input.


⚖️ License

This project is licensed under the GPLv3 License — see the LICENSE file for details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pyvideokit_gui-0.4.0-py3-none-any.whl (37.6 kB view details)

Uploaded Python 3

File details

Details for the file pyvideokit_gui-0.4.0-py3-none-any.whl.

File metadata

  • Download URL: pyvideokit_gui-0.4.0-py3-none-any.whl
  • Upload date:
  • Size: 37.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.4

File hashes

Hashes for pyvideokit_gui-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 50dbc43e8d640f76e916fabac5ee22fd857019230c0330837674bbe2f4c47633
MD5 ca0d510d8dd23ab8548b43db53106265
BLAKE2b-256 cc44d0bf3b4403cd1c2d9b691c0267d970903ff17611dc0679959963a01e64cf

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page