1
0
mirror of https://github.com/mpv-player/mpv synced 2024-12-26 00:42:57 +00:00
Command line video player
Go to file
wm4 89b8154aad command: auto-insert yadif when switching deinterlacing
If VO deinterlacing is unavailable, try to insert vf_yadif.

If vf_lavfi is available, actually use vf_yadif from libavfilter. The
libavfilter version of this filter is faster, more correct, etc., so it
is preferred. Unfortunately vf_yadif obviously doesn't support
VFCTRL_GET/SET_DEINTERLACE, and with the current state of the
libavfilter API, it doesn't look like there is any simple way to
emulate it. Instead, we simply insert the filter with a specific label,
and if deinterlacing is to be disabled, the filter is removed again by
label.

This won't do the right thing if the user inserts any deinterlacing
filter manually (except native vf_yadif, which understands the VFCTRL).
For example, with '-vf lavfi=yadif', pressing 'D' (toggle deinterlacing)
will just insert a second deinterlacer filter. In these cases, the user
is supposed to map a command that toggles his own filter instead of
using 'D' and the deinterlace property.

The same applies if the user wants to pass different parameters to the
deinterlacer filters.
2013-05-23 01:02:24 +02:00
audio chmap: fix oddity due to ambiguous 6.1 ffmpeg channel layout 2013-05-13 23:55:39 +02:00
compat compat: remove an unused symbol 2013-04-26 20:45:39 +02:00
core command: auto-insert yadif when switching deinterlacing 2013-05-23 01:02:24 +02:00
demux demux_lavf: workaround minor ffmpeg memory leak 2013-05-21 22:07:13 +02:00
DOCS m_option, vf: add label support 2013-05-23 01:02:24 +02:00
etc core: add playback resume feature (manual/opt-in) 2013-05-05 20:08:11 +02:00
osdep input: do property expansion for all input command string arguments 2013-05-18 17:45:55 +02:00
stream Silence some compiler warnings 2013-05-21 00:04:27 +02:00
sub add osd-scale command 2013-05-14 23:32:07 +02:00
TOOLS vf_dlopen framestep: step width of 0 2013-05-20 06:59:44 +02:00
video m_option, vf: add label support 2013-05-23 01:02:24 +02:00
.gitignore vo_opengl: split into multiple files, convert to new option API 2013-03-28 21:46:17 +01:00
.travis.yml travis: fix typo 2013-05-20 18:12:39 +02:00
AUTHORS
configure configure: map --enable-sdl2 to autodetection 2013-05-21 00:14:42 +02:00
Copyright Copyright: cleanup entries for removed code 2013-02-03 16:53:49 +01:00
LICENSE
Makefile Merge branch 'audio_changes' 2013-05-12 21:47:55 +02:00
README.md add Travis-CI integration 2013-05-19 20:41:40 +02:00
talloc.c talloc: fix strndup group of functions 2012-10-12 10:10:32 +02:00
talloc.h clang: fix all warnings except deprecations 2012-11-13 22:19:18 +01:00
travis-deps add Travis-CI integration 2013-05-19 20:41:40 +02:00
version.sh version.sh: fix git rev. generation (.git is not always a directory) 2013-02-06 23:03:37 +01:00

mpv

Build Status

Overview

mpv is a movie player based on MPlayer and mplayer2. It supports a wide variety of video file formats, audio and video codecs, and subtitle types.

If you are wondering what's different from mplayer2 and MPlayer you can read more about the changes.

Compilation

Compiling with full features requires development files for several external libraries. Below is a list of some important requirements. For more information see the output of ./configure --help for a list of options, or look at the list of enabled and disabled features printed after running ./configure. If you think you have support for some feature installed but configure fails to detect it, the file config.log may contain information about the reasons for the failure.

Essential dependencies (incomplete list):

  • gcc or clang
  • X development headers (xlib, X extensions, libvdpau, libGL, libXv, ...)
  • Audio output development headers (libasound, pulseaudio)
  • fribidi, freetype, fontconfig development headers (for libass)
  • libass
  • FFmpeg libraries (libavutil libavcodec libavformat libswscale libpostproc)
  • libjpeg
  • libquvi if you want to play Youtube videos directly
  • libx264 if you want to use encoding (has to be explicitly enabled when compiling ffmpeg)

Most of the above libraries are available in suitable versions on normal Linux distributions. However FFmpeg is an exception (distro versions may be too old to work at all or work well). For that reason you may want to use the separately available build wrapper (mpv-build) that first compiles FFmpeg libraries and libass, and then compiles the player statically linked against those.

If you are running Mac OSX and using homebrew we provide homebrew-mpv, an up to date formula that compiles mpv with sensible dependencies and defaults for OSX.

Bug reports

Please use the issue tracker provided by GitHub to send us bug reports or feature requests.

Contributing

For small changes you can just send us pull requests through GitHub. For bigger changes come and talk to us on IRC before you start working on them. It will make code review easier for both parties later on.

Contacts

You can find us on IRC in #mpv-player on irc.freenode.net