Simple GUI toolset for FFmpeg
Go to file
2025-12-30 16:09:33 -05:00
assets/logo Enhance Author module structure and implement drag-and-drop support 2025-12-22 20:09:43 -05:00
cmd/player_demo Implement VT_Player module with frame-accurate video playback 2025-12-21 16:31:44 -05:00
docs Remove refactoring and HandBrake replacement documentation files 2025-12-30 16:09:33 -05:00
internal Swap hover and selection UI colors 2025-12-30 12:02:55 -05:00
scripts Fix subtitle module drag and drop and remove emojis from scripts 2025-12-26 20:17:24 -05:00
.gitattributes Enforce LF endings for shell scripts 2025-12-13 21:30:17 -05:00
.gitignore feat(ui): Display codec badges inline with dropdowns 2025-12-29 02:27:44 -05:00
author_dvd_functions.go Finalize authoring workflow and update install docs 2025-12-23 14:24:09 -05:00
author_module.go Fix DVD authoring VOBU errors with proper MPEG-PS muxing 2025-12-30 15:41:03 -05:00
config_helpers.go Add persistent configs for author/subtitles/merge/rip 2025-12-24 15:39:22 -05:00
DONE.md Update DONE.md with benchmark UI cleanup feature 2025-12-28 22:21:33 -05:00
filters_module.go Add clear completed button to all module top bars 2025-12-29 22:02:35 -05:00
FyneApp.toml Mark dev20 across metadata 2025-12-23 14:39:44 -05:00
go.mod Implement in-app playback with ffmpeg frame pump and Go audio 2025-11-20 16:11:56 -05:00
go.sum Implement in-app playback with ffmpeg frame pump and Go audio 2025-11-20 16:11:56 -05:00
inspect_module.go Add clear completed button to all module top bars 2025-12-29 22:02:35 -05:00
main.go Update output filename preview in real-time when toggling suffix 2025-12-30 16:06:10 -05:00
main.go.backup-before-inspect-extraction Add thumb module files 2025-12-23 21:57:41 -05:00
merge_config.go Add persistent configs for author/subtitles/merge/rip 2025-12-24 15:39:22 -05:00
naming_helpers.go Make "-convert" suffix optional with checkbox (off by default) 2025-12-30 13:03:54 -05:00
platform.go Hide ffmpeg console windows on Windows and fix inspect clear button 2025-12-08 11:26:14 -05:00
PLAYER_PERFORMANCE_ISSUES.md Document and fix player module stuttering issues 2025-12-23 21:09:21 -05:00
README.md Update README.md 2025-12-24 00:31:55 +00:00
rip_module.go Add clear completed button to all module top bars 2025-12-29 22:02:35 -05:00
setup-windows.bat Add dev14 fixes: progress tracking, AMD AMF support, DVD resolution fix, and Windows build automation 2025-12-04 17:11:15 -05:00
subtitles_module.go Add clear completed button to all module top bars 2025-12-29 22:02:35 -05:00
thumb_module.go Add clear completed button to all module top bars 2025-12-29 22:02:35 -05:00
TODO_EXTRACTION_NOTES.md Phase 1 Complete: All upscale utilities migrated 2025-12-26 21:15:50 -05:00
TODO.md feat(author): Implement real-time progress, add to queue, clear title 2025-12-27 01:34:57 -05:00
upscale_module.go Fix build blockers and continue refactoring 2025-12-23 23:50:51 -05:00
VideoTools.desktop Add app icon support and window sizing improvements 2025-12-20 14:13:18 -05:00
WINDOWS_BUILD_PERFORMANCE.md Update Windows build guide for Git Bash users 2025-12-23 20:55:47 -05:00

VideoTools - Video Processing Suite

What is VideoTools?

VideoTools is a professional-grade video processing application with a modern GUI. It specializes in creating DVD-compliant videos for authoring and distribution.

Key Features

DVD-NTSC & DVD-PAL Output

  • Professional MPEG-2 encoding (720×480 @ 29.97fps for NTSC, 720×576 @ 25fps for PAL)
  • AC-3 Dolby Digital audio (192 kbps, 48 kHz)
  • DVDStyler compatible (no re-encoding warnings)
  • PS2 compatible (PS2-safe bitrate limits)
  • Region-free format (works worldwide)

Batch Processing

  • Queue multiple videos
  • Pause/resume jobs
  • Real-time progress tracking
  • Job history and persistence

Smart Features

  • Automatic framerate conversion (23.976p, 24p, 30p, 60p, VFR → 29.97fps)
  • Automatic audio resampling (any rate → 48 kHz)
  • Aspect ratio preservation with intelligent handling
  • Comprehensive validation with helpful warnings

Quick Start

Installation (One Command)

bash scripts/install.sh

The installer will build, install, and set up everything automatically with a guided wizard!

After installation:

source ~/.bashrc    # (or ~/.zshrc for zsh)
VideoTools

Alternative: Developer Setup

If you already have the repo cloned (dev workflow):

cd /path/to/VideoTools
bash scripts/build.sh
bash scripts/run.sh

For detailed installation options, troubleshooting, and platform-specific notes, see INSTALLATION.md. For upcoming work and priorities, see docs/ROADMAP.md.

How to Create a Professional DVD

  1. Start VideoToolsVideoTools
  2. Load a video → Drag & drop into Convert module
  3. Select format → Choose "DVD-NTSC (MPEG-2)" or "DVD-PAL (MPEG-2)"
  4. Choose aspect → Select 4:3 or 16:9
  5. Name output → Enter filename (without .mpg)
  6. Queue → Click "Add to Queue"
  7. Encode → Click "View Queue" → "Start Queue"
  8. Export → Use the .mpg file in DVDStyler

Output is professional quality, ready for:

  • DVDStyler authoring (no re-encoding needed)
  • DVD menu creation
  • Burning to disc
  • PS2 playback

Documentation

Getting Started:

  • INSTALLATION.md - Comprehensive installation guide (read this first!)

For Users:

  • BUILD_AND_RUN.md - How to build and run VideoTools
  • DVD_USER_GUIDE.md - Complete guide to DVD encoding

For Developers:

  • DVD_IMPLEMENTATION_SUMMARY.md - Technical specifications
  • INTEGRATION_GUIDE.md - System architecture and integration
  • QUEUE_SYSTEM_GUIDE.md - Queue system reference

Requirements

  • Go 1.21+ (for building)
  • FFmpeg (for video encoding)
  • X11 or Wayland display server (for GUI)

System Architecture

VideoTools has a modular architecture:

  • internal/convert/ - DVD and video encoding
  • internal/queue/ - Job queue system
  • internal/ui/ - User interface components
  • internal/player/ - Media playback
  • scripts/ - Build and run automation

Commands

Build & Run

# One-time setup
source scripts/alias.sh

# Run the application
VideoTools

# Force rebuild
VideoToolsRebuild

# Clean build artifacts
VideoToolsClean

Legacy (Direct commands)

# Build
go build -o VideoTools .

# Run
./VideoTools

# Run with debug logging
VIDEOTOOLS_DEBUG=1 ./VideoTools

# View logs
go run . logs

Troubleshooting

  • See BUILD_AND_RUN.md for detailed troubleshooting
  • Check videotools.log for detailed error messages
  • Use VIDEOTOOLS_DEBUG=1 for verbose logging

Professional Use Cases

  • Home video archival to physical media
  • Professional DVD authoring workflows
  • Multi-region video distribution
  • Content preservation on optical media
  • PS2 compatible video creation

Professional Quality Specifications

DVD-NTSC

  • Resolution: 720 × 480 pixels
  • Framerate: 29.97 fps (NTSC standard)
  • Video: MPEG-2 codec, 6000 kbps
  • Audio: AC-3 stereo, 192 kbps, 48 kHz
  • Regions: USA, Canada, Japan, Australia

DVD-PAL

  • Resolution: 720 × 576 pixels
  • Framerate: 25.00 fps (PAL standard)
  • Video: MPEG-2 codec, 8000 kbps
  • Audio: AC-3 stereo, 192 kbps, 48 kHz
  • Regions: Europe, Africa, Asia, Australia

Getting Help

  1. Read BUILD_AND_RUN.md for setup issues
  2. Read DVD_USER_GUIDE.md for how-to questions
  3. Check videotools.log for error details
  4. Review documentation in project root