Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/occivink/mpv-scripts
Various scripts for mpv
https://github.com/occivink/mpv-scripts
blur crop encode ffmpeg lua mpv script seek
Last synced: 3 months ago
JSON representation
Various scripts for mpv
- Host: GitHub
- URL: https://github.com/occivink/mpv-scripts
- Owner: occivink
- License: unlicense
- Created: 2016-11-04T18:44:52.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2024-06-04T16:52:08.000Z (8 months ago)
- Last Synced: 2024-08-02T15:54:28.203Z (6 months ago)
- Topics: blur, crop, encode, ffmpeg, lua, mpv, script, seek
- Language: Lua
- Homepage:
- Size: 111 KB
- Stars: 411
- Watchers: 14
- Forks: 38
- Open Issues: 38
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-mpv - encode - Re-encode or remux part of the current video. Can also preserve some filters, such as "crop". (Other)
README
# Foreword
These scripts are completely independent. Some of them work together nicely (e.g. `scripts/crop.lua` and `scripts/encode.lua`) but that's it. Just copy whichever scripts you're interested in to your `scripts/` directory (see [here](https://mpv.io/manual/master/#lua-scripting) for installation instructions).
[![demo](https://i.vimeocdn.com/filter/overlay?src0=https%3A%2F%2Fi.vimeocdn.com%2Fvideo%2F641523401_1280x720.jpg&src1=https%3A%2F%2Ff.vimeocdn.com%2Fimages_v6%2Fshare%2Fplay_icon_overlay.png)](https://vimeo.com/222879214)
## Bindings
None of these scripts come with default bindings. Instead, you should set your own in `input.conf`, see the example in this repo.
# crop.lua
Crop the current video in a visual manner.
UX largely inspired by [this script](https://github.com/aidanholm/mpv-easycrop), code is original. The main difference is that this script supports recursively cropping and is aware of some properties like pan or zoom, there are other subtleties.
Press the binding to enter crop mode. Click once to define the first corner of the cropped zone, click a second time to define the second corner.
Note that [hardware decoding is in general not compatible with filters](https://mpv.io/manual/master/#options-hwdec), and will therefore not work with this script.
# encode.lua
**You need ffmpeg in your PATH (or in the same folder as mpv) for this script to work.**
Make an extract of the video currently playing using `ffmpeg`.
Press the configured binding to set the beginning of the extract. Then, press ENTER to set the end and start encoding.
By default, the script creates a webm compatible with certain imageboards. You can create different profiles depending on the type of encode you want to create. In particular, you can change the codecs used, which tracks are active and the filters to apply.
See `script-opts/encode_webm.conf` for the default options and a description of them. `script-opts/encode_slice.conf` contains another example profile.
# seek-to.lua
Seek to an absolute position in the current video by typing its timestamp.
Toggle with whatever binding you chose. Move the current cursor position with ← and →, Change the number currently selected with the number keys (duh). Press Enter to seek to the entered position.
Holds an internal history for timestamps that have been previously navigated, accessible with ↑ and ↓.# blacklist-extensions.lua
Automatically remove playlist entries by extension according to a black/whitelist. Useful when opening directories with mpv.
The script doesn't do anything by default, you need to copy `script-opts/blacklist_extensions.conf` and modify it to your liking.
# blur-edges.lua
Fills the black bars on the side of a video with a blurred copy of its edges.
The script defines a `toggle-blur` command that you can bind.
It can be configured via `script-opts/blur_edges.conf`.# misc.lua
Some commands that are too simple to warrant their own script. Have a look at the source in case you're curious.