Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/occivink/mpv-gallery-view
Gallery-view scripts for mpv
https://github.com/occivink/mpv-gallery-view
gallery lua mpv script
Last synced: 3 months ago
JSON representation
Gallery-view scripts for mpv
- Host: GitHub
- URL: https://github.com/occivink/mpv-gallery-view
- Owner: occivink
- License: unlicense
- Created: 2017-12-31T09:38:07.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2023-11-06T09:31:04.000Z (about 1 year ago)
- Last Synced: 2024-08-03T09:04:47.725Z (6 months ago)
- Topics: gallery, lua, mpv, script
- Language: Lua
- Homepage:
- Size: 202 KB
- Stars: 191
- Watchers: 12
- Forks: 20
- Open Issues: 19
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-mpv - contact-sheet - Display thumbnails of the current file in the style of a contact sheet. (Image)
README
Playlist view and [contact sheet](https://en.wikipedia.org/wiki/Contact_print) scripts for [mpv](https://github.com/mpv-player/mpv).
[![demo](https://i.vimeocdn.com/video/811681643.jpg)](https://vimeo.com/358137972)
# Important
* **Make sure that the thumbnail directory exists for thumbnail generation to work.**
* The default directories are: `~/.cache/thumbnails/mpv-gallery` on Unix, `%APPDATA%\mpv\gallery-thumbs-dir` on Windows. See Configuration for instructions on how to change it.# Installation
Copy the .lua files in `scripts/` to your mpv scripts directory (See [mpv's manual](https://mpv.io/manual/master/#files)). Copy `script-modules/gallery.lua` to a directory called script-modules. This directory should be alongside the scripts directory in mpv's config path. Create the directories, if not already present.
If you are not interested in the playlist view or contact sheet, respectively remove the [`playlist-view.lua`](scripts/playlist-view.lua) or [`contact-sheet.lua`](scripts/contact-sheet.lua) files.
You can make multiple copies (or symlinks) of [`gallery-thumbgen.lua`](scripts/gallery-thumbgen.lua) to speed up thumbnail generation, they will register themselves automatically.
# Usage
By default, the playlist-view can be opened with `g` and the contact-sheet with `c`.
In both you can navigate around using arrow keys or the mouse.
When you activate an item in the playlist-view, it will switch to that file. In the contact sheet, it will seek to that timestamp.
# Configuration
Both scripts can be configured through the usual `script-opts` mechanism of mpv (see its [manual](https://mpv.io/manual/master/#files)). The files [`contact_sheet.conf`](script-opts/contact_sheet.conf) and [`playlist_view.conf`](script-opts/playlist_view.conf) in this repository contain a detailed list of options.
Note that both scripts cannot be used at the same time, as they compete for the same resources. If you want to use both, I recommend using the following input.conf bindings:
```
g script-message contact-sheet-close; script-message playlist-view-toggle
c script-message playlist-view-close; script-message contact-sheet-toggle
```
To ensure that only one of the scripts is active at a time.# Playlist-view flagging
When the playlist-view is open, you can flag playlist entries (using `SPACE` by default). Flagged entries are indicated with a small frame. Then, when exiting mpv a text file will be created (default `./mpv_gallery_flagged`) containing the filenames of the flagged entries, one per line.
# Limitations
Yet another ad-hoc thumbnail library, which is not shared with any other program.
Management of the thumbnails is left to the user. In particular, stale thumbnails (whose file has been (re)moved) are not deleted by the script. This can be fixed by deleting thumbnails which have not been accessed since N days with such a snippet:
```
days=7
min=$((days * 60 * 24))
# run first without -delete to be sure
find ~/.cache/thumbnails/mpv-gallery/ -maxdepth 1 -type f -amin +$min -delete
```Thumbnails are raw bgra, which is somewhat wasteful. With the default settings, a thumbnail uses 81KB (around 13k thumbnails in a GB).
Due to an [mpv bug](https://github.com/mpv-player/mpv/issues/8350), the playlist-view or contact-sheet might not appear right away when toggled. Using the mpv config `video-sync=display-resample` or the script config `pause_on_start=no` indirectly solves the problem.