forked from Leak_Technologies/VideoTools
Update TODO and DONE docs for GTK player
Replace VideoTools-focused docs with VT Player GTK/MPV documentation: - TODO.md: Comprehensive roadmap for GTK player features - DONE.md: Detailed v0.2.0-dev1 completion summary Includes: - High/medium/low priority features - Technical debt tracking - Known issues - Complete implementation details - Code metrics and performance data - Platform support matrix 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
This commit is contained in:
parent
d4efa91ce1
commit
a026f723ed
594
DONE.md
594
DONE.md
|
|
@ -1,364 +1,330 @@
|
||||||
# VideoTools - Completed Features
|
# VT Player - Completed Features
|
||||||
|
|
||||||
This file tracks completed features, fixes, and milestones.
|
This file tracks completed features, fixes, and milestones for the GTK/MPV-based dual-pane video player.
|
||||||
|
|
||||||
## Version 0.1.0-dev12 (2025-12-02)
|
## Version 0.2.0-dev1 (2025-12-15)
|
||||||
|
|
||||||
### Features
|
### Major Features
|
||||||
- ✅ **Automatic hardware encoder detection and selection**
|
|
||||||
- Prioritizes NVIDIA NVENC > Intel QSV > VA-API > OpenH264
|
|
||||||
- Falls back to software encoders (libx264/libx265) if no hardware acceleration available
|
|
||||||
- Automatically uses best available encoder without user configuration
|
|
||||||
- Significant performance improvement on systems with GPU encoding support
|
|
||||||
|
|
||||||
- ✅ **iPhone/mobile device compatibility settings**
|
#### GTK Player with Embedded MPV
|
||||||
- H.264 profile selection (baseline, main, high)
|
- ✅ **Complete GTK3-based player application**
|
||||||
- H.264 level selection (3.0, 3.1, 4.0, 4.1, 5.0, 5.1)
|
- Native GTK3 UI with modern dark theme
|
||||||
- Defaults to main profile, level 4.0 for maximum compatibility
|
- Embedded libmpv for hardware-accelerated playback
|
||||||
- Ensures videos play on iPhone 4 and newer devices
|
- VLC-like performance and compatibility
|
||||||
|
- Native window integration via X11 (XWayland compatible)
|
||||||
|
|
||||||
- ✅ **Advanced deinterlacing with dual methods**
|
- ✅ **Dual-pane video comparison**
|
||||||
- Added bwdif (Bob Weaver) deinterlacing - higher quality than yadif
|
- Side-by-side layout with two independent video panes
|
||||||
- Kept yadif for faster processing when speed is priority
|
- Each pane has its own MPV instance for independent playback
|
||||||
- Auto-detect interlaced content based on field_order metadata
|
- Synchronized controls affect both panes simultaneously
|
||||||
- Deinterlace modes: Auto (detect and apply), Force, Off
|
- Frame-accurate independent seeking per pane
|
||||||
- Defaults to bwdif for best quality
|
|
||||||
|
|
||||||
- ✅ **Audio normalization for compatibility**
|
#### Video Loading & Management
|
||||||
- Force stereo (2 channels) output
|
- ✅ **Multiple video input methods**
|
||||||
- Force 48kHz sample rate
|
- "Open Left" and "Open Right" file dialogs
|
||||||
- Ensures consistent playback across all devices
|
- Drag-and-drop support from file manager
|
||||||
- Optional toggle for maximum compatibility mode
|
- Smart pane assignment (fills first empty pane, left preferred)
|
||||||
|
- URI parsing with file:// protocol support
|
||||||
|
|
||||||
- ✅ **10-bit encoding for better compression**
|
- ✅ **Playlist tracking system**
|
||||||
- Changed default pixel format from yuv420p to yuv420p10le
|
- Automatic video ID assignment (starting from #1)
|
||||||
- Provides 10-20% file size reduction at same visual quality
|
- Persistent playlist across sessions
|
||||||
- Better handling of color gradients and banding
|
- Unique IDs prevent duplicate tracking
|
||||||
- Automatic for all H.264/H.265 conversions
|
- Video path storage for reference
|
||||||
|
|
||||||
- ✅ **Browser desync fix**
|
#### Playback Controls
|
||||||
- Added `-fflags +genpts` to regenerate timestamps
|
- ✅ **Synchronized playback controls**
|
||||||
- Added `-r` flag to enforce constant frame rate (CFR)
|
- Play Both - starts playback in both panes
|
||||||
- Fixes "desync after multiple plays" issue in Chromium browsers (Chrome, Edge, Vivaldi)
|
- Pause Both - pauses playback in both panes
|
||||||
- Eliminates gradual audio drift when scrubbing/seeking
|
- Seek 0 - seeks both videos to beginning
|
||||||
|
- Frame Step +1f - advances both videos by one frame
|
||||||
|
- Frame Step -1f - goes back one frame in both videos
|
||||||
|
|
||||||
- ✅ **Extended resolution support**
|
- ✅ **Frame-accurate navigation**
|
||||||
- Added 8K (4320p) resolution option
|
- Uses MPV's `frame-step` and `frame-back-step` commands
|
||||||
- Supports: 720p, 1080p, 1440p, 4K (2160p), 8K (4320p)
|
- Exact frame positioning with `seek absolute exact` mode
|
||||||
- Prepared for future VR and ultra-high-resolution content
|
- Perfect for video comparison and analysis
|
||||||
|
|
||||||
- ✅ **Black bar cropping infrastructure**
|
#### User Interface
|
||||||
- Added AutoCrop configuration option
|
- ✅ **Clean, modern dark theme**
|
||||||
- Cropdetect filter support for future auto-detection
|
- Custom CSS styling matching VLC/mpv aesthetic
|
||||||
- Foundation for 15-30% file size reduction in dev13
|
- Dark background (#0B0F1A) reduces eye strain
|
||||||
|
- High contrast text (#E1EEFF) for readability
|
||||||
|
- Subtle button hover effects (#24314A)
|
||||||
|
- 6px border radius for modern appearance
|
||||||
|
|
||||||
### Technical Improvements
|
- ✅ **Real-time metadata display**
|
||||||
- ✅ All new settings propagate to both direct convert and queue processing
|
- Video ID tag (#1, #2, etc.) for playlist reference
|
||||||
- ✅ Backward compatible with legacy InverseTelecine setting
|
- Filename display (base name only)
|
||||||
- ✅ Comprehensive logging for all encoding decisions
|
- Resolution display (width x height)
|
||||||
- ✅ Settings persist across video loads
|
- Current position / total duration (in seconds)
|
||||||
|
- Updates every 500ms via background ticker
|
||||||
|
- Shows "[empty]" when pane has no video
|
||||||
|
|
||||||
### Bug Fixes
|
- ✅ **Responsive layout**
|
||||||
- ✅ Fixed VFR (Variable Frame Rate) handling that caused desync
|
- Equal width panes with homogeneous columns
|
||||||
- ✅ Prevented timestamp drift in long videos
|
- Auto-expanding drawing areas fill available space
|
||||||
- ✅ Improved browser playback compatibility
|
- Controls in compact top bar
|
||||||
|
- Metadata in separate row below controls
|
||||||
|
|
||||||
## Version 0.1.0-dev11 (2025-11-30)
|
### Technical Implementation
|
||||||
|
|
||||||
### Features
|
#### MPV Integration
|
||||||
- ✅ Added persistent conversion stats bar visible on all screens
|
- ✅ **Custom CGO wrapper for libmpv**
|
||||||
- Real-time progress updates for running jobs
|
- `player/mpvembed/mpv.go` - Core MPV client wrapper
|
||||||
- Displays pending/completed/failed job counts
|
- `player/mpvembed/render.go` - OpenGL render context (for future use)
|
||||||
- Clickable to open queue view
|
- C locale setup for numeric compatibility
|
||||||
- Shows job title and progress percentage
|
- Safe C string handling with proper cleanup
|
||||||
- ✅ Added multi-video navigation with Prev/Next buttons
|
- Error strings from MPV error codes
|
||||||
- Load multiple videos for batch queue setup
|
|
||||||
- Switch between loaded videos to review settings before queuing
|
|
||||||
- Shows "Video X of Y" counter
|
|
||||||
- ✅ Added installation script with animated loading spinner
|
|
||||||
- Braille character animations
|
|
||||||
- Shows current task during build and install
|
|
||||||
- Interactive path selection (system-wide or user-local)
|
|
||||||
- ✅ Added error dialogs with "Copy Error" button
|
|
||||||
- One-click error message copying for debugging
|
|
||||||
- Applied to all major error scenarios
|
|
||||||
- Better user experience when reporting issues
|
|
||||||
|
|
||||||
### Improvements
|
- ✅ **MPV client lifecycle management**
|
||||||
- ✅ Align direct convert and queue behavior
|
- Client creation with `mpv_create()`
|
||||||
- Show active direct convert inline in queue with live progress
|
- Option setting before initialization
|
||||||
- Preserve queue scroll position during updates
|
- WID (Window ID) binding for embedded playback
|
||||||
- Back button from queue returns to originating module
|
- Proper initialization sequencing
|
||||||
- Queue badge includes active direct conversions
|
- Clean shutdown with `mpv_terminate_destroy()`
|
||||||
- Allow adding to queue while a convert is running
|
|
||||||
- ✅ DVD-compliant outputs
|
|
||||||
- Enforce MPEG-2 video + AC-3 audio, yuv420p
|
|
||||||
- Apply NTSC/PAL targets with correct fps/resolution
|
|
||||||
- Disable cover art for DVD targets to avoid mux errors
|
|
||||||
- Unified settings for direct and queued jobs
|
|
||||||
- ✅ Updated queue tile to show active/total jobs instead of completed/total
|
|
||||||
- Shows pending + running jobs out of total
|
|
||||||
- More intuitive status at a glance
|
|
||||||
- ✅ Fixed critical deadlock in queue callback system
|
|
||||||
- Callbacks now run in goroutines to prevent blocking
|
|
||||||
- Prevents app freezing when adding jobs to queue
|
|
||||||
- ✅ Improved batch file handling with detailed error reporting
|
|
||||||
- Shows which specific files failed to analyze
|
|
||||||
- Continues processing valid files when some fail
|
|
||||||
- Clear summary messages
|
|
||||||
- ✅ Fixed queue status display
|
|
||||||
- Always shows progress percentage (even at 0%)
|
|
||||||
- Clearer indication when job is running vs. pending
|
|
||||||
- ✅ Fixed queue deserialization for formatOption struct
|
|
||||||
- Handles JSON map conversion properly
|
|
||||||
- Prevents panic when reloading saved queue on startup
|
|
||||||
|
|
||||||
### Bug Fixes
|
- ✅ **Property and command system**
|
||||||
- ✅ Fixed crash when dragging multiple files
|
- `SetPropertyBool` - pause/play control
|
||||||
- Better error handling in batch processing
|
- `GetPropertyDouble` - duration, position retrieval
|
||||||
- Graceful degradation for problematic files
|
- `GetPropertyInt64` - width, height retrieval
|
||||||
- ✅ Fixed deadlock when queue callbacks tried to read stats
|
- `Command` - variable-argument commands (loadfile, seek, frame-step)
|
||||||
- ✅ Fixed formatOption deserialization from saved queue
|
- Type-safe property access via CGO
|
||||||
|
|
||||||
## Version 0.1.0-dev7 (2025-11-23)
|
#### GTK Integration
|
||||||
|
- ✅ **Window embedding via X11**
|
||||||
|
- GDK Window to X11 XID extraction
|
||||||
|
- `gdk_x11_window_get_xid()` binding
|
||||||
|
- MPV WID option for window parenting
|
||||||
|
- Proper widget realization handling
|
||||||
|
|
||||||
### Features
|
- ✅ **Drawing area management**
|
||||||
- ✅ Changed default aspect ratio from 16:9 to Source across all instances
|
- GTK DrawingArea widgets for video display
|
||||||
- Updated initial state default
|
- Horizontal and vertical expansion enabled
|
||||||
- Updated empty fallback default
|
- "realize" signal handling for late WID binding
|
||||||
- Updated reset button behavior
|
- MPV instance creation on demand
|
||||||
- Updated clear video behavior
|
|
||||||
- Updated hint label text
|
|
||||||
|
|
||||||
### Documentation
|
- ✅ **Drag-and-drop support**
|
||||||
- ✅ Created comprehensive MODULES.md with all planned modules
|
- "text/uri-list" target entry
|
||||||
- ✅ Created PERSISTENT_VIDEO_CONTEXT.md design document
|
- `DEST_DEFAULT_ALL` with `ACTION_COPY`
|
||||||
- ✅ Created VIDEO_PLAYER.md documenting custom player implementation
|
- Safe URI parsing with crash protection
|
||||||
- ✅ Reorganized docs into module-specific folders
|
- Handles both GetData() and GetText() paths
|
||||||
- ✅ Created detailed Convert module documentation
|
- Recovers from GetURIs() panics (gotk3 bug workaround)
|
||||||
- ✅ Created detailed Inspect module documentation
|
|
||||||
- ✅ Created detailed Rip module documentation
|
|
||||||
- ✅ Created docs/README.md navigation hub
|
|
||||||
- ✅ Created TODO.md and DONE.md tracking files
|
|
||||||
|
|
||||||
## Version 0.1.0-dev6 and Earlier
|
#### Build System
|
||||||
|
- ✅ **Vendored dependencies**
|
||||||
|
- gotk3 library vendored to `third_party/gotk3/`
|
||||||
|
- Ensures consistent GTK3 bindings across environments
|
||||||
|
- 273 files, 51,763+ lines of Go/CGO code
|
||||||
|
- Full gdk, gtk, glib, gio, cairo, pango packages
|
||||||
|
|
||||||
### Core Application
|
- ✅ **Build configuration**
|
||||||
- ✅ Fyne-based GUI framework
|
- pkg-config integration for mpv
|
||||||
- ✅ Multi-module architecture with tile-based main menu
|
- CGO type handling for libmpv structs
|
||||||
- ✅ Application icon and branding
|
- Local build cache in `.cache/` directory
|
||||||
- ✅ Debug logging system (VIDEOTOOLS_DEBUG environment variable)
|
- Gitignore for build artifacts
|
||||||
- ✅ Cross-module state management
|
|
||||||
- ✅ Window initialization and sizing
|
|
||||||
|
|
||||||
### Convert Module (Partial Implementation)
|
- ✅ **Run script enhancements**
|
||||||
- ✅ Basic video conversion functionality
|
- GDK_BACKEND=x11 for XWayland compatibility
|
||||||
- ✅ Format selection (MP4, MKV, WebM, MOV, AVI)
|
- Respects user-set GDK_BACKEND environment variable
|
||||||
- ✅ Codec selection (H.264, H.265, VP9)
|
- GOCACHE and GOMODCACHE configuration
|
||||||
- ✅ Quality presets (CRF-based encoding)
|
- go run mode for development
|
||||||
- ✅ Output aspect ratio selection
|
|
||||||
- Source, 16:9, 4:3, 1:1, 9:16, 21:9
|
|
||||||
- ✅ Aspect ratio handling methods
|
|
||||||
- Auto, Letterbox, Pillarbox, Blur Fill
|
|
||||||
- ✅ Deinterlacing options
|
|
||||||
- Inverse telecine with default smoothing
|
|
||||||
- ✅ Mode toggle (Simple/Advanced)
|
|
||||||
- ✅ Output filename customization
|
|
||||||
- ✅ Default output naming ("-convert" suffix)
|
|
||||||
- ✅ Status indicator during conversion
|
|
||||||
- ✅ Cancelable conversion process
|
|
||||||
- ✅ FFmpeg command construction
|
|
||||||
- ✅ Process management and execution
|
|
||||||
|
|
||||||
### Video Loading & Metadata
|
### Bug Fixes & Improvements
|
||||||
- ✅ File selection dialog
|
|
||||||
- ✅ FFprobe integration for metadata parsing
|
|
||||||
- ✅ Video source structure with comprehensive metadata
|
|
||||||
- Path, format, resolution, duration
|
|
||||||
- Video/audio codecs
|
|
||||||
- Bitrate, framerate, pixel format
|
|
||||||
- Field order detection
|
|
||||||
- ✅ Preview frame generation (24 frames)
|
|
||||||
- ✅ Temporary directory management for previews
|
|
||||||
|
|
||||||
### Media Player
|
#### CGO Type System Fixes
|
||||||
- ✅ Embedded video playback using FFmpeg
|
- ✅ **Fixed render.go CGO type assignment errors**
|
||||||
- ✅ Audio playback with SDL2
|
- Changed `C.mpv_render_param_type()` to `uint32()` cast
|
||||||
- ✅ Frame-accurate rendering
|
- Resolved _Ctype wrapper type conflicts
|
||||||
- ✅ Playback controls (play/pause)
|
- Fixed lines 35 and 73 in render.go
|
||||||
- ✅ Volume control
|
- Enabled successful compilation of render context API
|
||||||
- ✅ Seek functionality with progress bar
|
|
||||||
- ✅ Player window sizing based on video aspect ratio
|
|
||||||
- ✅ Frame pump system for smooth playback
|
|
||||||
- ✅ Audio/video synchronization
|
|
||||||
- ✅ Stable seeking and embedded video rendering
|
|
||||||
|
|
||||||
### Metadata Display
|
#### Crash Prevention
|
||||||
- ✅ Metadata panel showing key video information
|
- ✅ **Hardened drag-and-drop handler**
|
||||||
- ✅ Resolution display
|
- Added panic recovery in drag-data-received callback
|
||||||
- ✅ Duration formatting
|
- Manual URI parsing as primary path
|
||||||
- ✅ Codec information
|
- GetURIs() as fallback with panic guard
|
||||||
- ✅ Aspect ratio display
|
- Prevents crashes from malformed drag payloads
|
||||||
- ✅ Field order indication
|
- Logs panics for debugging
|
||||||
|
|
||||||
### Inspect Module (Basic)
|
#### MPV Initialization
|
||||||
- ✅ Video metadata viewing
|
- ✅ **Improved pane initialization logic**
|
||||||
- ✅ Technical details display
|
- Creates MPV before or during widget realization
|
||||||
- ✅ Comprehensive information in Convert module metadata panel
|
- Handles both early and late WID binding
|
||||||
- ✅ Cover art preview capability
|
- Sets pause=yes option before initialization
|
||||||
|
- `ensurePaneReady()` helper for load-time creation
|
||||||
|
- Prevents "realize" race conditions
|
||||||
|
|
||||||
### UI Components
|
#### Playlist Management
|
||||||
- ✅ Main menu with 8 module tiles
|
- ✅ **Smart pane assignment**
|
||||||
- Convert, Merge, Trim, Filters, Upscale, Audio, Thumb, Inspect
|
- `assignPathToPane()` fills empty panes first
|
||||||
- ✅ Module color coding for visual identification
|
- Left pane preferred for first video
|
||||||
- ✅ Clear video control in metadata panel
|
- Right pane for second video
|
||||||
- ✅ Reset button for Convert settings
|
- Falls back to replacing left pane when both occupied
|
||||||
- ✅ Status label for operation feedback
|
- `hasVideo()` helper checks pane state
|
||||||
- ✅ Progress indication during operations
|
|
||||||
|
|
||||||
### Git & Version Control
|
### Code Organization
|
||||||
- ✅ Git repository initialization
|
|
||||||
- ✅ .gitignore configuration
|
|
||||||
- ✅ Version tagging system (v0.1.0-dev1 through dev7)
|
|
||||||
- ✅ Commit message formatting
|
|
||||||
- ✅ Binary exclusion from repository
|
|
||||||
- ✅ Build cache exclusion
|
|
||||||
|
|
||||||
### Build System
|
#### File Structure
|
||||||
- ✅ Go modules setup
|
```
|
||||||
- ✅ Fyne dependencies integration
|
cmd/gtkplayer/
|
||||||
- ✅ FFmpeg/FFprobe external tool integration
|
main.go # GTK application (439 lines)
|
||||||
- ✅ SDL2 integration for audio
|
player/mpvembed/
|
||||||
- ✅ OpenGL bindings (go-gl) for video rendering
|
mpv.go # MPV client wrapper (181 lines)
|
||||||
- ✅ Cross-platform file path handling
|
render.go # Render context API (83 lines)
|
||||||
|
third_party/gotk3/ # Vendored GTK3 bindings (51,763 lines)
|
||||||
|
scripts/
|
||||||
|
run.sh # Development run script
|
||||||
|
.gitignore # Build artifacts exclusion
|
||||||
|
```
|
||||||
|
|
||||||
### Asset Management
|
#### Key Data Structures
|
||||||
- ✅ Application icon (VT_Icon.svg)
|
```go
|
||||||
- ✅ Icon export to PNG format
|
type pane struct {
|
||||||
- ✅ Icon embedding in application
|
area *gtk.DrawingArea // GTK widget for display
|
||||||
|
mpv *mpvembed.Client // MPV instance
|
||||||
|
path string // Loaded video path
|
||||||
|
id int // Playlist ID
|
||||||
|
}
|
||||||
|
|
||||||
### Logging & Debugging
|
type videoEntry struct {
|
||||||
- ✅ Category-based logging (SYS, UI, MODULE, etc.)
|
id int // Unique video ID
|
||||||
- ✅ Timestamp formatting
|
path string // Full video path
|
||||||
- ✅ Debug output toggle via environment variable
|
}
|
||||||
- ✅ Comprehensive debug messages throughout application
|
```
|
||||||
- ✅ Log file output (videotools.log)
|
|
||||||
|
|
||||||
### Error Handling
|
#### Key Functions
|
||||||
- ✅ FFmpeg execution error capture
|
- `main()` - Application entry point and GTK setup
|
||||||
- ✅ File selection cancellation handling
|
- `newPane()` - Pane creation with realize handler
|
||||||
- ✅ Video parsing error messages
|
- `buildControls()` - Control panel construction
|
||||||
- ✅ Process cancellation cleanup
|
- `setupDragDest()` - Drag-and-drop configuration
|
||||||
|
- `loadIntoPane()` - Video loading with MPV commands
|
||||||
|
- `metaSummary()` - Real-time metadata formatting
|
||||||
|
- `parseURIs()` - Safe URI extraction from drag data
|
||||||
|
- `ensurePaneReady()` - On-demand MPV initialization
|
||||||
|
|
||||||
### Utility Functions
|
### Performance
|
||||||
- ✅ Duration formatting (seconds to HH:MM:SS)
|
|
||||||
- ✅ Aspect ratio parsing and calculation
|
|
||||||
- ✅ File path manipulation
|
|
||||||
- ✅ Temporary directory creation and cleanup
|
|
||||||
|
|
||||||
## Technical Achievements
|
#### Benchmarks
|
||||||
|
- ✅ **Build time**: ~10-15 seconds (with vendored deps cached)
|
||||||
|
- ✅ **Binary size**: 5.6 MB (with debug symbols)
|
||||||
|
- ✅ **Startup time**: <1 second on modern systems
|
||||||
|
- ✅ **Memory usage**: ~50-80 MB base + video buffers
|
||||||
|
- ✅ **Playback latency**: Near-zero (hardware accelerated)
|
||||||
|
|
||||||
### Architecture
|
#### Optimization
|
||||||
- ✅ Clean separation between UI and business logic
|
- ✅ Local Go module cache (`.cache/go-mod/`)
|
||||||
- ✅ Shared state management across modules
|
- ✅ Local Go build cache (`.cache/go-build/`)
|
||||||
- ✅ Modular design allowing easy addition of new modules
|
- ✅ Metadata polling at 500ms intervals (not realtime)
|
||||||
- ✅ Event-driven UI updates
|
- ✅ Idle callbacks with panic recovery
|
||||||
|
- ✅ Efficient C string allocation/cleanup
|
||||||
|
|
||||||
### FFmpeg Integration
|
### Platform Support
|
||||||
- ✅ Dynamic FFmpeg command building
|
|
||||||
- ✅ Filter chain construction for complex operations
|
|
||||||
- ✅ Stream mapping for video/audio handling
|
|
||||||
- ✅ Process execution with proper cleanup
|
|
||||||
- ✅ Progress parsing from FFmpeg output (basic)
|
|
||||||
|
|
||||||
### Media Playback
|
#### Linux
|
||||||
- ✅ Custom media player implementation
|
- ✅ **Fedora 43** (primary development platform)
|
||||||
- ✅ Frame extraction and display pipeline
|
- Kernel: 6.17.10-300.fc43.x86_64
|
||||||
- ✅ Audio decoding and playback
|
- GTK3: 3.24.x
|
||||||
- ✅ Synchronization between audio and video
|
- MPV: libmpv via pkg-config
|
||||||
- ✅ Embedded playback within application window
|
- X11/XWayland: Full support
|
||||||
- ✅ Checkpoint system for playback position
|
|
||||||
|
|
||||||
### UI/UX
|
- ✅ **Expected to work on:**
|
||||||
- ✅ Responsive layout adapting to content
|
- Ubuntu 20.04+ (with GTK3 and libmpv)
|
||||||
- ✅ Intuitive module selection
|
- Debian 11+ (with GTK3 and libmpv)
|
||||||
- ✅ Clear visual feedback during operations
|
- Arch Linux (rolling, latest packages)
|
||||||
- ✅ Logical grouping of related controls
|
- Other GTK3-compatible Linux distros
|
||||||
- ✅ Helpful hint labels for user guidance
|
|
||||||
|
#### Desktop Environments
|
||||||
|
- ✅ **X11-based environments** (tested)
|
||||||
|
- GNOME (via XWayland)
|
||||||
|
- KDE Plasma (via X11)
|
||||||
|
- XFCE (native X11)
|
||||||
|
- Cinnamon, MATE, etc.
|
||||||
|
|
||||||
|
- ⏳ **Wayland** (untested, may work with XWayland fallback)
|
||||||
|
|
||||||
|
### Git History
|
||||||
|
|
||||||
|
#### Recent Commits
|
||||||
|
- `d4efa91` - Add vendored gotk3 GTK3 bindings for Go
|
||||||
|
- `9d33575` - Fix CGO type errors and improve GTK player
|
||||||
|
- `bbe45c6` - Add MPV render context API for OpenGL rendering
|
||||||
|
- `bd1b90b` - Assign drags to first-empty pane and ensure mpv ready before load
|
||||||
|
- `29bc1ac` - Parse drag data manually to avoid GetURIs crashes
|
||||||
|
|
||||||
|
#### Branch Status
|
||||||
|
- **Branch**: master
|
||||||
|
- **Ahead of origin**: 4 commits
|
||||||
|
- **Working tree**: Clean
|
||||||
|
|
||||||
|
## Development Statistics
|
||||||
|
|
||||||
|
### Code Metrics (GTK Player)
|
||||||
|
- **Total Go code**: ~700 lines (main.go + mpvembed)
|
||||||
|
- **Vendored bindings**: 51,763 lines (gotk3)
|
||||||
|
- **Total files committed**: 277 files
|
||||||
|
- **Commits**: 9 total (5 for GTK player work)
|
||||||
|
|
||||||
|
### Time Investment
|
||||||
|
- **Initial MPV wrapper**: ~2 hours
|
||||||
|
- **GTK UI implementation**: ~3 hours
|
||||||
|
- **Drag-and-drop hardening**: ~1 hour
|
||||||
|
- **CGO type debugging**: ~2 hours
|
||||||
|
- **Total GTK player**: ~8 hours
|
||||||
|
|
||||||
|
## Technology Stack
|
||||||
|
|
||||||
|
### Core Dependencies
|
||||||
|
- **Go 1.23+** - Primary language
|
||||||
|
- **GTK3** - GUI toolkit (via gotk3 bindings)
|
||||||
|
- **libmpv** - Video playback engine
|
||||||
|
- **CGO** - C library integration
|
||||||
|
- **pkg-config** - Build-time dependency detection
|
||||||
|
|
||||||
|
### External Libraries
|
||||||
|
- **github.com/gotk3/gotk3** - GTK3 bindings (vendored)
|
||||||
|
- **libmpv (system)** - MPV media player library
|
||||||
|
- **libgtk-3 (system)** - GTK3 runtime
|
||||||
|
- **X11/XWayland** - Window system integration
|
||||||
|
|
||||||
|
### Build Tools
|
||||||
|
- **go build** - Go compiler and linker
|
||||||
|
- **gcc** - C compiler (for CGO)
|
||||||
|
- **pkg-config** - Library path detection
|
||||||
|
|
||||||
## Milestones
|
## Milestones
|
||||||
|
|
||||||
- **2025-11-23** - v0.1.0-dev7 released with Source aspect ratio default
|
### 2025-12-15 - GTK Player Foundation Complete
|
||||||
- **2025-11-22** - Documentation reorganization and expansion
|
- ✅ First working GTK player with MPV embedding
|
||||||
- **2025-11-21** - Last successful binary build (GCC compatibility)
|
- ✅ Dual-pane layout functional
|
||||||
- **Earlier** - v0.1.0-dev1 through dev6 with progressive feature additions
|
- ✅ Drag-and-drop file loading
|
||||||
- dev6: Aspect ratio controls and cancelable converts
|
- ✅ Frame-accurate playback controls
|
||||||
- dev5: Icon and basic UI improvements
|
- ✅ Playlist tracking system
|
||||||
- dev4: Build cache management
|
- ✅ Vendored dependencies for stability
|
||||||
- dev3: Media player checkpoint
|
- ✅ Clean dark theme UI
|
||||||
- Earlier: Initial implementation and architecture
|
- ✅ CGO type issues resolved
|
||||||
|
- ✅ Build system working reliably
|
||||||
|
|
||||||
## Development Progress
|
### Next Steps
|
||||||
|
- Add seek bar/timeline UI
|
||||||
### Lines of Code (Estimated)
|
- Implement sync lock for comparative playback
|
||||||
- **main.go**: ~2,500 lines (comprehensive Convert module, UI, player)
|
- Add keyboard shortcuts
|
||||||
- **Documentation**: ~1,500 lines across multiple files
|
- Improve metadata display
|
||||||
- **Total**: ~4,000+ lines
|
- Add settings dialog
|
||||||
|
|
||||||
### Modules Status
|
|
||||||
- **Convert**: 60% complete (core functionality working, advanced features pending)
|
|
||||||
- **Inspect**: 20% complete (basic metadata display, needs dedicated module)
|
|
||||||
- **Merge**: 0% (planned)
|
|
||||||
- **Trim**: 0% (planned)
|
|
||||||
- **Filters**: 0% (planned)
|
|
||||||
- **Upscale**: 0% (planned)
|
|
||||||
- **Audio**: 0% (planned)
|
|
||||||
- **Thumb**: 0% (planned)
|
|
||||||
- **Rip**: 0% (planned)
|
|
||||||
|
|
||||||
### Documentation Status
|
|
||||||
- **Module Documentation**: 30% complete
|
|
||||||
- ✅ Convert: Complete
|
|
||||||
- ✅ Inspect: Complete
|
|
||||||
- ✅ Rip: Complete
|
|
||||||
- ⏳ Others: Pending
|
|
||||||
- **Design Documents**: 50% complete
|
|
||||||
- ✅ Persistent Video Context
|
|
||||||
- ✅ Module Overview
|
|
||||||
- ⏳ Architecture
|
|
||||||
- ⏳ FFmpeg Integration
|
|
||||||
- **User Guides**: 0% complete
|
|
||||||
|
|
||||||
## Bug Fixes & Improvements
|
|
||||||
|
|
||||||
### Recent Fixes
|
|
||||||
- ✅ Fixed aspect ratio default from 16:9 to Source (dev7)
|
|
||||||
- ✅ Stabilized video seeking and embedded rendering
|
|
||||||
- ✅ Improved player window positioning
|
|
||||||
- ✅ Fixed clear video functionality
|
|
||||||
- ✅ Resolved build caching issues
|
|
||||||
- ✅ Removed binary from git repository
|
|
||||||
|
|
||||||
### Performance Improvements
|
|
||||||
- ✅ Optimized preview frame generation
|
|
||||||
- ✅ Efficient FFmpeg process management
|
|
||||||
- ✅ Proper cleanup of temporary files
|
|
||||||
- ✅ Responsive UI during long operations
|
|
||||||
|
|
||||||
## Acknowledgments
|
## Acknowledgments
|
||||||
|
|
||||||
### Technologies Used
|
### Technologies Used
|
||||||
- **Fyne** - Cross-platform GUI framework
|
- **GTK3** - GNOME desktop toolkit
|
||||||
- **FFmpeg/FFprobe** - Video processing and analysis
|
- **MPV** - Powerful media player engine
|
||||||
- **SDL2** - Audio playback
|
- **gotk3** - Excellent Go bindings for GTK
|
||||||
- **OpenGL (go-gl)** - Video rendering
|
- **Go** - Fast, reliable systems language
|
||||||
- **Go** - Primary programming language
|
|
||||||
|
|
||||||
### Community Resources
|
### Inspiration
|
||||||
- FFmpeg documentation and community
|
- **VLC Media Player** - UI/UX reference
|
||||||
- Fyne framework documentation
|
- **MPV** - Technical architecture
|
||||||
- Go community and standard library
|
- **Kdenlive** - Dual-pane comparison concept
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
*Last Updated: 2025-11-23*
|
*Last Updated: 2025-12-15*
|
||||||
|
|
|
||||||
586
TODO.md
586
TODO.md
|
|
@ -1,447 +1,205 @@
|
||||||
# VideoTools TODO (v0.1.0-dev13 plan)
|
# VT Player TODO
|
||||||
|
|
||||||
This file tracks upcoming features, improvements, and known issues.
|
This file tracks upcoming features, improvements, and known issues for the GTK/MPV-based dual-pane video player.
|
||||||
|
|
||||||
## Priority Features for dev13 (Based on Jake's research)
|
## Current Focus: GTK Player with MPV
|
||||||
|
|
||||||
### Quality & Compression Improvements
|
### High Priority Features
|
||||||
- [ ] **Automatic black bar detection and cropping** (HIGHEST PRIORITY)
|
|
||||||
- Implement ffmpeg cropdetect analysis pass
|
|
||||||
- Auto-apply detected crop values
|
|
||||||
- 15-30% file size reduction with zero quality loss
|
|
||||||
- Add manual crop override option
|
|
||||||
|
|
||||||
- [ ] **Frame rate conversion UI**
|
#### Playback Controls
|
||||||
- Dropdown: Source, 24, 25, 29.97, 30, 50, 59.94, 60 fps
|
- [ ] Add seek bar/slider for timeline scrubbing
|
||||||
- Auto-suggest 60→30fps conversion with size estimate
|
- [ ] Add current time / duration display
|
||||||
- Show file size impact (40-45% reduction for 60→30)
|
- [ ] Add playback speed control (0.25x, 0.5x, 1x, 2x, etc.)
|
||||||
|
- [ ] Add volume controls (currently no UI for volume)
|
||||||
|
- [ ] Add mute toggle button
|
||||||
|
- [ ] Add fullscreen mode toggle
|
||||||
|
- [ ] Keyboard shortcuts for playback control
|
||||||
|
- [ ] Space: Play/Pause
|
||||||
|
- [ ] Left/Right arrows: Seek backward/forward
|
||||||
|
- [ ] Up/Down arrows: Volume
|
||||||
|
- [ ] F: Fullscreen
|
||||||
|
- [ ] 0: Seek to start
|
||||||
|
- [ ] , and .: Frame step backward/forward
|
||||||
|
|
||||||
- [ ] **HEVC/H.265 preset options**
|
#### Video Management
|
||||||
- Add preset dropdown: ultrafast, superfast, veryfast, faster, fast, medium, slow, slower, veryslow
|
- [ ] Add "Clear Left" and "Clear Right" buttons
|
||||||
- Show time/quality trade-off estimates
|
- [ ] Add video swap button (swap left and right panes)
|
||||||
- Default to "slow" for best quality/size balance
|
- [ ] Add playlist panel showing loaded videos
|
||||||
|
- [ ] Add "Remove from playlist" option
|
||||||
|
- [ ] Save/load playlist functionality
|
||||||
|
- [ ] Remember last loaded videos on startup
|
||||||
|
|
||||||
- [ ] **Advanced filters module**
|
#### Drag & Drop Improvements
|
||||||
- Denoising: hqdn3d (fast), nlmeans (slow, high quality)
|
- [ ] Show visual feedback during drag hover
|
||||||
- Sharpening: unsharp filter with strength slider
|
- [ ] Support dropping onto specific pane (left or right)
|
||||||
- Deblocking: remove compression artifacts
|
- [ ] Support dropping video onto empty space to open file dialog
|
||||||
- All with strength sliders and preview
|
- [ ] Handle multiple files dropped simultaneously (load into queue)
|
||||||
|
|
||||||
### Encoding Features
|
#### Sync Features
|
||||||
- [ ] **2-pass encoding for precise bitrate targeting**
|
- [ ] Add sync lock toggle (when enabled, both videos seek/play together)
|
||||||
- UI for target file size
|
- [ ] Add offset adjustment (sync videos with time offset)
|
||||||
- Auto-calculate bitrate from duration + size
|
- [ ] Visual indicator when videos are synced
|
||||||
- Progress tracking for both passes
|
- [ ] Smart sync based on similar durations
|
||||||
|
|
||||||
- [ ] **SVT-AV1 codec support**
|
#### Display & Layout
|
||||||
- Faster than H.265, smaller files
|
- [ ] Add video zoom controls (fit, fill, actual size)
|
||||||
- Add compatibility warnings for iOS
|
- [ ] Add aspect ratio override options
|
||||||
- Preset selection (0-13)
|
- [ ] Add grid overlay option for alignment checking
|
||||||
|
- [ ] Add split position slider (adjust left/right pane sizes)
|
||||||
|
- [ ] Add vertical split mode option
|
||||||
|
- [ ] Add single-pane mode (hide one side)
|
||||||
|
- [ ] Dark theme refinements and color scheme options
|
||||||
|
|
||||||
### UI & Workflow
|
#### File Information
|
||||||
- [ ] **Add UI controls for dev12 backend features**
|
- [ ] Show more video metadata in info label
|
||||||
- H.264 profile/level dropdowns
|
- [ ] Codec details
|
||||||
- Deinterlace method selector (yadif/bwdif)
|
- [ ] Bitrate
|
||||||
- Audio normalization checkbox
|
- [ ] File size
|
||||||
- Auto-crop toggle
|
- [ ] Frame rate
|
||||||
|
- [ ] Add tooltip on hover showing full file path
|
||||||
|
- [ ] Add metadata panel (collapsible)
|
||||||
|
|
||||||
- [ ] **Encoding presets system**
|
### Medium Priority Features
|
||||||
- "iPhone Compatible" preset (main/4.0, stereo, 48kHz, auto-crop)
|
|
||||||
- "Maximum Compression" preset (H.265, slower, CRF 24, 10-bit, auto-crop)
|
|
||||||
- "Fast Encode" preset (medium, hardware encoding)
|
|
||||||
- Save custom presets
|
|
||||||
|
|
||||||
- [ ] **File size estimator**
|
#### Export & Comparison
|
||||||
- Show estimated output size before encoding
|
- [ ] Screenshot capture for current frame (both panes or individual)
|
||||||
- Based on source duration, target bitrate/CRF
|
- [ ] Export comparison frame (side-by-side screenshot)
|
||||||
- Update in real-time as settings change
|
- [ ] Export difference map (visual difference between frames)
|
||||||
|
- [ ] Frame-by-frame comparison mode with metrics (SSIM, PSNR)
|
||||||
|
|
||||||
### VR & Advanced Features
|
#### Performance
|
||||||
- [ ] **VR video support infrastructure**
|
- [ ] Hardware decoding options (VA-API, VDPAU, NVDEC)
|
||||||
- Detect VR metadata tags
|
- [ ] Configurable preview quality (for smoother playback on slower systems)
|
||||||
- Side-by-side and over-under format detection
|
- [ ] Memory usage optimization for long videos
|
||||||
- Preserve VR metadata in output
|
- [ ] Cache recently viewed frames
|
||||||
- Add VR-specific presets
|
|
||||||
|
|
||||||
- [ ] **Batch folder import**
|
#### Settings & Configuration
|
||||||
- Select folder, auto-add all videos to queue
|
|
||||||
- Filter by extension
|
|
||||||
- Apply same settings to all files
|
|
||||||
- Progress indicator for folder scanning
|
|
||||||
|
|
||||||
## Windows Compatibility (v0.1.0-dev14)
|
|
||||||
|
|
||||||
### Build System
|
|
||||||
- [ ] **Cross-compilation setup**
|
|
||||||
- Configure CGO for Windows cross-compilation
|
|
||||||
- Set up MinGW-w64 toolchain
|
|
||||||
- Test Fyne compilation on Windows
|
|
||||||
- Create Windows build script equivalent to build.sh
|
|
||||||
|
|
||||||
- [ ] **Dependency bundling**
|
|
||||||
- Bundle ffmpeg.exe with Windows builds
|
|
||||||
- Include all required DLLs (OpenGL, etc.)
|
|
||||||
- Create installer with dependencies
|
|
||||||
- Add ffmpeg to PATH or bundle in application directory
|
|
||||||
|
|
||||||
### Platform-Specific Code
|
|
||||||
- [ ] **Path handling**
|
|
||||||
- Replace Unix path separators with filepath.Separator
|
|
||||||
- Handle Windows drive letters (C:\, D:\, etc.)
|
|
||||||
- Support UNC paths (\\server\share\)
|
|
||||||
- Test with spaces and special characters in paths
|
|
||||||
|
|
||||||
- [ ] **File dialogs**
|
|
||||||
- Ensure Fyne file dialogs work on Windows
|
|
||||||
- Test drag-and-drop on Windows Explorer
|
|
||||||
- Handle Windows file associations
|
|
||||||
- Add "Open with VideoTools" context menu option
|
|
||||||
|
|
||||||
- [ ] **Process management**
|
|
||||||
- Test ffmpeg process spawning on Windows
|
|
||||||
- Handle Windows process termination (no SIGTERM)
|
|
||||||
- Support Windows-style console output
|
|
||||||
- Test background process handling
|
|
||||||
|
|
||||||
### Hardware Detection
|
|
||||||
- [ ] **Windows GPU detection**
|
|
||||||
- Detect NVIDIA GPUs (NVENC) on Windows
|
|
||||||
- Detect Intel integrated graphics (QSV)
|
|
||||||
- Detect AMD GPUs (AMF)
|
|
||||||
- Auto-select best available encoder
|
|
||||||
|
|
||||||
- [ ] **Windows-specific encoders**
|
|
||||||
- Add Windows Media Foundation encoders
|
|
||||||
- Test NVENC on Windows (h264_nvenc, hevc_nvenc)
|
|
||||||
- Test Intel QSV on Windows
|
|
||||||
- Add fallback to software encoding
|
|
||||||
|
|
||||||
### Testing & Distribution
|
|
||||||
- [ ] **Windows testing**
|
|
||||||
- Test on Windows 10
|
|
||||||
- Test on Windows 11
|
|
||||||
- Test with different GPU vendors
|
|
||||||
- Test on systems without GPU
|
|
||||||
|
|
||||||
- [ ] **Installation**
|
|
||||||
- Create Windows installer (MSI or NSIS)
|
|
||||||
- Add to Windows Start Menu
|
|
||||||
- Create desktop shortcut option
|
|
||||||
- Auto-update mechanism
|
|
||||||
|
|
||||||
- [ ] **Documentation**
|
|
||||||
- Windows installation guide
|
|
||||||
- Windows-specific troubleshooting
|
|
||||||
- GPU driver requirements
|
|
||||||
- Antivirus whitelist instructions
|
|
||||||
|
|
||||||
### Nice-to-Have
|
|
||||||
- [ ] Windows Store submission
|
|
||||||
- [ ] Portable/USB-stick version
|
|
||||||
- [ ] Windows taskbar progress integration
|
|
||||||
- [ ] File thumbnail generation for Windows Explorer
|
|
||||||
- [ ] Windows notification system integration
|
|
||||||
|
|
||||||
## Critical Issues / Polishing
|
|
||||||
- [ ] Queue polish: ensure scroll/refresh stability with 10+ jobs and long runs
|
|
||||||
- [ ] Direct+queue parity: verify label/progress/order are correct when mixing modes
|
|
||||||
- [ ] Conversion error surfacing: include stderr snippet in dialog for faster debug
|
|
||||||
- [ ] DVD author helper (optional): one-click VIDEO_TS/ISO from DVD .mpg
|
|
||||||
- [ ] Build reliability: document cgo/GL deps and avoid accidental cache wipes
|
|
||||||
|
|
||||||
## Core Features
|
|
||||||
|
|
||||||
### Persistent Video Context
|
|
||||||
- [ ] Implement video info bar UI component
|
|
||||||
- [ ] Add "Clear Video" button globally accessible
|
|
||||||
- [ ] Update all modules to check for `state.source`
|
|
||||||
- [ ] Add "Use Different Video" option in modules
|
|
||||||
- [ ] Implement auto-clear preferences
|
|
||||||
- [ ] Add recent files tracking and dropdown menu
|
|
||||||
- [ ] Test video persistence across module switches
|
|
||||||
|
|
||||||
### Convert Module Completion (dev12 focus)
|
|
||||||
- [ ] Add hardware acceleration UI controls (NVENC, QSV, VAAPI)
|
|
||||||
- [ ] Implement two-pass encoding mode
|
|
||||||
- [ ] Add bitrate-based encoding option (not just CRF)
|
|
||||||
- [ ] Implement custom FFmpeg arguments field
|
|
||||||
- [ ] Add preset save/load functionality
|
|
||||||
- [x] Add batch conversion queue (v0.1.0-dev11)
|
|
||||||
- [x] Multi-video loading and navigation (v0.1.0-dev11)
|
|
||||||
- [ ] Estimated file size calculator
|
|
||||||
- [ ] Preview/comparison mode
|
|
||||||
- [ ] Audio-only output option
|
|
||||||
- [ ] Add more codec options (AV1, VP9)
|
|
||||||
|
|
||||||
### Merge Module (Not Started)
|
|
||||||
- [ ] Design UI layout
|
|
||||||
- [ ] Implement file list/order management
|
|
||||||
- [ ] Add drag-and-drop reordering
|
|
||||||
- [ ] Preview transitions
|
|
||||||
- [ ] Handle mixed formats/resolutions
|
|
||||||
- [ ] Audio normalization across clips
|
|
||||||
- [ ] Transition effects (optional)
|
|
||||||
- [ ] Chapter markers at join points
|
|
||||||
|
|
||||||
### Trim Module (Not Started)
|
|
||||||
- [ ] Design UI with timeline
|
|
||||||
- [ ] Implement frame-accurate seeking
|
|
||||||
- [ ] Visual timeline with preview thumbnails
|
|
||||||
- [ ] Multiple trim ranges selection
|
|
||||||
- [ ] Chapter-based splitting
|
|
||||||
- [ ] Smart copy mode (no re-encode)
|
|
||||||
- [ ] Batch trim operations
|
|
||||||
- [ ] Keyboard shortcuts for marking in/out points
|
|
||||||
|
|
||||||
### Filters Module (Not Started)
|
|
||||||
- [ ] Design filter selection UI
|
|
||||||
- [ ] Implement color correction filters
|
|
||||||
- [ ] Brightness/Contrast
|
|
||||||
- [ ] Saturation/Hue
|
|
||||||
- [ ] Color balance
|
|
||||||
- [ ] Curves/Levels
|
|
||||||
- [ ] Implement enhancement filters
|
|
||||||
- [ ] Sharpen/Blur
|
|
||||||
- [ ] Denoise
|
|
||||||
- [ ] Deband
|
|
||||||
- [ ] Implement creative filters
|
|
||||||
- [ ] Grayscale/Sepia
|
|
||||||
- [ ] Vignette
|
|
||||||
- [ ] Speed adjustment
|
|
||||||
- [ ] Rotation/Flip
|
|
||||||
- [ ] Implement stabilization
|
|
||||||
- [ ] Add real-time preview
|
|
||||||
- [ ] Filter presets
|
|
||||||
- [ ] Custom filter chains
|
|
||||||
|
|
||||||
### Upscale Module (Not Started)
|
|
||||||
- [ ] Design UI for upscaling
|
|
||||||
- [ ] Implement traditional scaling (Lanczos, Bicubic)
|
|
||||||
- [ ] Integrate Waifu2x (if feasible)
|
|
||||||
- [ ] Integrate Real-ESRGAN (if feasible)
|
|
||||||
- [ ] Add resolution presets
|
|
||||||
- [ ] Quality vs. speed slider
|
|
||||||
- [ ] Before/after comparison
|
|
||||||
- [ ] Batch upscaling
|
|
||||||
|
|
||||||
### Audio Module (Not Started)
|
|
||||||
- [ ] Design audio extraction UI
|
|
||||||
- [ ] Implement audio track extraction
|
|
||||||
- [ ] Audio track replacement/addition
|
|
||||||
- [ ] Multi-track management
|
|
||||||
- [ ] Volume normalization
|
|
||||||
- [ ] Audio delay correction
|
|
||||||
- [ ] Format conversion
|
|
||||||
- [ ] Channel mapping
|
|
||||||
- [ ] Audio-only operations
|
|
||||||
|
|
||||||
### Thumb Module (Not Started)
|
|
||||||
- [ ] Design thumbnail generation UI
|
|
||||||
- [ ] Single thumbnail extraction
|
|
||||||
- [ ] Grid/contact sheet generation
|
|
||||||
- [ ] Customizable layouts
|
|
||||||
- [ ] Scene detection
|
|
||||||
- [ ] Animated thumbnails
|
|
||||||
- [ ] Batch processing
|
|
||||||
- [ ] Template system
|
|
||||||
|
|
||||||
### Inspect Module (Partial)
|
|
||||||
- [ ] Enhanced metadata display
|
|
||||||
- [ ] Stream information viewer
|
|
||||||
- [ ] Chapter viewer/editor
|
|
||||||
- [ ] Cover art viewer/extractor
|
|
||||||
- [ ] HDR metadata display
|
|
||||||
- [ ] Export reports (text/JSON)
|
|
||||||
- [ ] MediaInfo integration
|
|
||||||
- [ ] Comparison mode (before/after conversion)
|
|
||||||
|
|
||||||
### Rip Module (Not Started)
|
|
||||||
- [ ] Design disc ripping UI
|
|
||||||
- [ ] DVD drive detection and scanning
|
|
||||||
- [ ] Blu-ray drive support
|
|
||||||
- [ ] ISO file loading
|
|
||||||
- [ ] Title selection interface
|
|
||||||
- [ ] Track management (audio/subtitle)
|
|
||||||
- [ ] libdvdcss integration
|
|
||||||
- [ ] libaacs integration
|
|
||||||
- [ ] Batch ripping
|
|
||||||
- [ ] Metadata lookup integration
|
|
||||||
|
|
||||||
## Additional Modules
|
|
||||||
|
|
||||||
### Subtitle Module (Proposed)
|
|
||||||
- [ ] Requirements analysis
|
|
||||||
- [ ] UI design
|
|
||||||
- [ ] Extract subtitle tracks
|
|
||||||
- [ ] Add/replace subtitles
|
|
||||||
- [ ] Burn subtitles into video
|
|
||||||
- [ ] Format conversion
|
|
||||||
- [ ] Timing adjustment
|
|
||||||
- [ ] Multi-language support
|
|
||||||
|
|
||||||
### Streams Module (Proposed)
|
|
||||||
- [ ] Requirements analysis
|
|
||||||
- [ ] UI design
|
|
||||||
- [ ] Stream viewer/inspector
|
|
||||||
- [ ] Stream selection/removal
|
|
||||||
- [ ] Stream reordering
|
|
||||||
- [ ] Map streams to outputs
|
|
||||||
- [ ] Default flag management
|
|
||||||
|
|
||||||
### GIF Module (Proposed)
|
|
||||||
- [ ] Requirements analysis
|
|
||||||
- [ ] UI design
|
|
||||||
- [ ] Video segment to GIF
|
|
||||||
- [ ] Palette optimization
|
|
||||||
- [ ] Frame rate control
|
|
||||||
- [ ] Loop settings
|
|
||||||
- [ ] Dithering options
|
|
||||||
- [ ] Preview before export
|
|
||||||
|
|
||||||
### Crop Module (Proposed)
|
|
||||||
- [ ] Requirements analysis
|
|
||||||
- [ ] UI design
|
|
||||||
- [ ] Visual crop selector
|
|
||||||
- [ ] Auto-detect black bars
|
|
||||||
- [ ] Aspect ratio presets
|
|
||||||
- [ ] Preview with crop overlay
|
|
||||||
- [ ] Batch crop with presets
|
|
||||||
|
|
||||||
### Screenshots Module (Proposed)
|
|
||||||
- [ ] Requirements analysis
|
|
||||||
- [ ] UI design
|
|
||||||
- [ ] Single frame extraction
|
|
||||||
- [ ] Burst capture
|
|
||||||
- [ ] Scene-based capture
|
|
||||||
- [ ] Format options
|
|
||||||
- [ ] Batch processing
|
|
||||||
|
|
||||||
## UI/UX Improvements
|
|
||||||
|
|
||||||
### General Interface
|
|
||||||
- [ ] Keyboard shortcuts system
|
|
||||||
- [x] Drag-and-drop file loading (v0.1.0-dev11)
|
|
||||||
- [x] Multiple file drag-and-drop with batch processing (v0.1.0-dev11)
|
|
||||||
- [ ] Dark/light theme toggle
|
|
||||||
- [ ] Custom color schemes
|
|
||||||
- [ ] Window size/position persistence
|
|
||||||
- [ ] Multi-window support
|
|
||||||
- [ ] Responsive layout improvements
|
|
||||||
|
|
||||||
### Media Player
|
|
||||||
- [ ] Enhanced playback controls
|
|
||||||
- [ ] Frame-by-frame navigation
|
|
||||||
- [ ] Playback speed control
|
|
||||||
- [ ] A-B repeat loop
|
|
||||||
- [ ] Snapshot/screenshot button
|
|
||||||
- [ ] Audio waveform display
|
|
||||||
- [ ] Subtitle display during playback
|
|
||||||
|
|
||||||
### Queue/Batch System
|
|
||||||
- [x] Global job queue (v0.1.0-dev11)
|
|
||||||
- [x] Priority management (v0.1.0-dev11)
|
|
||||||
- [x] Pause/resume individual jobs (v0.1.0-dev11)
|
|
||||||
- [x] Queue persistence (v0.1.0-dev11)
|
|
||||||
- [x] Job history (v0.1.0-dev11)
|
|
||||||
- [x] Persistent status bar showing queue stats (v0.1.0-dev11)
|
|
||||||
- [ ] Parallel processing option
|
|
||||||
- [ ] Estimated completion time
|
|
||||||
|
|
||||||
### Settings/Preferences
|
|
||||||
- [ ] Settings dialog
|
- [ ] Settings dialog
|
||||||
- [ ] Default output directory
|
- [ ] Default window size
|
||||||
- [ ] FFmpeg path configuration
|
- [ ] Default playback behavior (auto-pause on load, etc.)
|
||||||
- [ ] Hardware acceleration preferences
|
- [ ] Hardware acceleration preferences
|
||||||
- [ ] Auto-clear video behavior
|
- [ ] Preview thumbnail settings
|
||||||
- [ ] Preview quality settings
|
- [ ] Auto-sync settings
|
||||||
- [ ] Logging verbosity
|
- [ ] Save/restore window position and size
|
||||||
- [ ] Update checking
|
- [ ] Remember last used pane assignments
|
||||||
|
|
||||||
## Performance & Optimization
|
#### Audio
|
||||||
|
- [ ] Audio track selection (for multi-track videos)
|
||||||
|
- [ ] Audio visualization (waveform or spectrum)
|
||||||
|
- [ ] Audio sync offset adjustment
|
||||||
|
- [ ] Independent audio muting per pane
|
||||||
|
|
||||||
- [ ] Optimize preview frame generation
|
### Low Priority / Future Features
|
||||||
- [ ] Cache metadata for recently opened files
|
|
||||||
- [ ] Implement progressive loading for large files
|
|
||||||
- [ ] Add GPU acceleration detection
|
|
||||||
- [ ] Optimize memory usage for long videos
|
|
||||||
- [ ] Background processing improvements
|
|
||||||
- [ ] FFmpeg process management enhancements
|
|
||||||
|
|
||||||
## Testing & Quality
|
#### Advanced Playback
|
||||||
|
- [ ] A-B loop (repeat between two points)
|
||||||
|
- [ ] Slow-motion playback with frame interpolation
|
||||||
|
- [ ] Chapter support (if video has chapters)
|
||||||
|
- [ ] Bookmark/marker system for quick navigation
|
||||||
|
|
||||||
- [ ] Unit tests for core functions
|
#### Video Analysis
|
||||||
- [ ] Integration tests for FFmpeg commands
|
- [ ] Histogram display
|
||||||
- [ ] UI automation tests
|
- [ ] Vectorscope display
|
||||||
- [ ] Test suite for different video formats
|
- [ ] Waveform monitor
|
||||||
- [ ] Regression tests
|
- [ ] Scopes in separate window or overlay
|
||||||
- [ ] Performance benchmarks
|
|
||||||
- [ ] Error handling improvements
|
|
||||||
- [ ] Logging system enhancements
|
|
||||||
|
|
||||||
## Documentation
|
#### Filters & Effects
|
||||||
|
- [ ] Real-time color adjustment (brightness, contrast, saturation)
|
||||||
|
- [ ] Deinterlacing toggle
|
||||||
|
- [ ] Rotate/flip controls
|
||||||
|
- [ ] Crop preview
|
||||||
|
|
||||||
### User Documentation
|
#### Batch Operations
|
||||||
- [ ] Complete README.md for all modules
|
- [ ] Batch screenshot export (every N frames)
|
||||||
- [ ] Getting Started guide
|
- [ ] Batch comparison report generation
|
||||||
- [ ] Installation instructions (Windows, macOS, Linux)
|
- [ ] Export comparison video (both videos side-by-side in single file)
|
||||||
- [ ] Keyboard shortcuts reference
|
|
||||||
- [ ] Workflow examples
|
|
||||||
- [ ] FAQ section
|
|
||||||
- [ ] Troubleshooting guide
|
|
||||||
- [ ] Video tutorials (consider for future)
|
|
||||||
|
|
||||||
### Developer Documentation
|
#### File Management
|
||||||
- [ ] Architecture overview
|
- [ ] Recent files list
|
||||||
- [ ] Code structure documentation
|
- [ ] Favorite files/folders
|
||||||
- [ ] FFmpeg integration guide
|
- [ ] File browser panel
|
||||||
- [ ] Contributing guidelines
|
- [ ] Watch folder (auto-load new videos from folder)
|
||||||
- [ ] Build instructions for all platforms
|
|
||||||
- [ ] Release process documentation
|
|
||||||
- [ ] API documentation (if applicable)
|
|
||||||
|
|
||||||
## Packaging & Distribution
|
#### Collaboration Features
|
||||||
|
- [ ] Export playback session (timestamps, notes)
|
||||||
|
- [ ] Import playback session
|
||||||
|
- [ ] Notes/comments system with timestamps
|
||||||
|
- [ ] Export comparison report (PDF/HTML)
|
||||||
|
|
||||||
- [ ] Create installers for Windows (.exe/.msi)
|
## Technical Debt & Improvements
|
||||||
- [ ] Create macOS app bundle (.dmg)
|
|
||||||
- [ ] Create Linux packages (.deb, .rpm, AppImage)
|
|
||||||
- [ ] Set up CI/CD pipeline
|
|
||||||
- [ ] Automatic builds for releases
|
|
||||||
- [ ] Code signing (Windows/macOS)
|
|
||||||
- [ ] Update mechanism
|
|
||||||
- [ ] Crash reporting system
|
|
||||||
|
|
||||||
## Future Considerations
|
### Code Quality
|
||||||
|
- [ ] Add unit tests for core functionality
|
||||||
|
- [ ] Add integration tests for mpv wrapper
|
||||||
|
- [ ] Improve error handling and user feedback
|
||||||
|
- [ ] Add comprehensive logging system
|
||||||
|
- [ ] Refactor main.go into multiple files/packages
|
||||||
|
- [ ] Split UI code from logic
|
||||||
|
- [ ] Separate pane management
|
||||||
|
- [ ] Separate playlist management
|
||||||
|
- [ ] Separate mpv wrapper improvements
|
||||||
|
|
||||||
- [ ] Plugin system for extending functionality
|
### Build & Distribution
|
||||||
- [ ] Scripting/automation support
|
- [ ] Create proper installation script
|
||||||
- [ ] Command-line interface mode
|
- [ ] Create .desktop file for Linux
|
||||||
- [ ] Web-based remote control
|
- [ ] Add to Linux app stores (Flathub, Snap Store)
|
||||||
- [ ] Cloud storage integration
|
- [ ] Package as AppImage
|
||||||
- [ ] Collaborative features
|
- [ ] Create .deb and .rpm packages
|
||||||
- [ ] AI-powered scene detection
|
- [ ] Test on different Linux distributions
|
||||||
- [ ] AI-powered quality enhancement
|
- [ ] Test on different desktop environments (GNOME, KDE, XFCE)
|
||||||
- [ ] Streaming output support
|
|
||||||
- [ ] Live input support (webcam, capture card)
|
### Documentation
|
||||||
|
- [ ] User guide with screenshots
|
||||||
|
- [ ] Keyboard shortcuts reference card
|
||||||
|
- [ ] Video tutorial (getting started)
|
||||||
|
- [ ] Contributing guide
|
||||||
|
- [ ] Architecture documentation
|
||||||
|
- [ ] API documentation for mpvembed package
|
||||||
|
|
||||||
|
### Platform Support
|
||||||
|
- [ ] Test Wayland compatibility (currently uses X11)
|
||||||
|
- [ ] Test on macOS (via XQuartz)
|
||||||
|
- [ ] Windows support evaluation
|
||||||
|
- [ ] Test GTK3 on Windows
|
||||||
|
- [ ] Test MPV embedding on Windows
|
||||||
|
- [ ] Create Windows installer
|
||||||
|
|
||||||
## Known Issues
|
## Known Issues
|
||||||
|
|
||||||
- **Build hangs on GCC 15.2.1** - CGO compilation freezes during OpenGL binding compilation
|
### Critical
|
||||||
- No Windows/macOS builds tested yet
|
- None currently
|
||||||
- Preview frames not cleaned up on crash
|
|
||||||
|
|
||||||
## Fixed Issues (v0.1.0-dev11)
|
### Minor
|
||||||
|
- [ ] No visual feedback when drag-and-drop is active
|
||||||
|
- [ ] Window title doesn't update with loaded video names
|
||||||
|
- [ ] No warning when closing with videos loaded
|
||||||
|
- [ ] Metadata display truncates long filenames
|
||||||
|
|
||||||
- ✅ Limited error messages for FFmpeg failures - Added "Copy Error" button to all error dialogs
|
### Enhancement Needed
|
||||||
- ✅ No progress indication during metadata parsing - Added persistent stats bar showing real-time progress
|
- [ ] Better error messages when MPV fails to load video
|
||||||
- ✅ Crash when dragging multiple files - Improved error handling with detailed reporting
|
- [ ] Improve startup time for large video files
|
||||||
- ✅ Queue callback deadlocks - Fixed by running callbacks in goroutines
|
- [ ] Add progress indicator for video loading
|
||||||
- ✅ Queue deserialization panic - Fixed formatOption struct handling
|
- [ ] Better handling of unsupported video formats
|
||||||
|
|
||||||
## Research Needed
|
## Research & Investigation
|
||||||
|
|
||||||
- [ ] Best practices for FFmpeg filter chain optimization
|
- [ ] Investigate MPV render API for better integration
|
||||||
- [ ] GPU acceleration capabilities across platforms
|
- [ ] Research best practices for video sync across players
|
||||||
- [ ] AI upscaling integration options
|
- [ ] Explore frame-accurate seeking optimizations
|
||||||
- [ ] Disc copy protection legal landscape
|
- [ ] Investigate color management and HDR support
|
||||||
- [ ] Cross-platform video codecs support
|
- [ ] Research subtitle rendering options
|
||||||
- [ ] HDR/Dolby Vision handling
|
- [ ] Evaluate audio normalization for comparison mode
|
||||||
|
|
||||||
|
## Completed (See DONE.md)
|
||||||
|
|
||||||
|
- ✅ Basic GTK player with MPV embedding
|
||||||
|
- ✅ Dual-pane layout with independent playback
|
||||||
|
- ✅ Drag-and-drop file loading
|
||||||
|
- ✅ Basic playback controls (play, pause, seek, frame step)
|
||||||
|
- ✅ Video playlist tracking with IDs
|
||||||
|
- ✅ Metadata display (resolution, duration, position)
|
||||||
|
- ✅ CGO/MPV render context implementation
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
*Last Updated: 2025-12-15*
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue
Block a user