V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
Distributions
Ubuntu
Fedora
CentOS
中文资源站
网易开源镜像站
raawaa
V2EX  ›  Linux

mpv 播放视频要好久才出画面

  •  
  •   raawaa ·
    raawaa · Jan 8, 2016 · 5886 views
    This topic created in 3766 days ago, the information mentioned may be changed or developed.
    好奇怪的问题,不报任何错误,但是刚开始只有窗口没有任何画面,等了好久……视频画面出来了。

    用 mplayer 的话就没有问题。
    Supplement 1  ·  Jan 9, 2016

    帖一下解决方案

    首先说一下为什么我为什么会遇到这么奇葩的问题

    我的机器是 archlinux+xfce , Fontconfig 的字体配置文件是手打的,于是少写了关于字体信息缓存文件夹的设置。这个少写其实没什么大问题,因为通常 Fontconfig 会出个 warning 然后自己替我设个默认值。然而执行 mpv -v 苍老师.avi 的时候,输出信息一直卡在了这一行:

    [osd/libass] Setting up fonts...
    

    在 github 上找到了一个类似的 issue,其中提到问题源自 libass 和 Fontconfig 。于是想到了我少打的那行fonts.conf配置。猜测是因为 mpv 每次找不到字体信息的 cache ,导致每次启动 mpv 时都要把系统里的字体都 caching 一遍,所以好久才开始播放画面。

    如何解决

    确保 Fontconfig 的配置文件里有关于 cachedir 的配置

    <?xml version="1.0"?>
    <!DOCTYPE fontconfig SYSTEM "fonts.dtd">
    <!-- $XDG_CONFIG_HOME/fontconfig/fonts.conf for per-user font configuration -->
    
    <fontconfig>
    ...
      <cachedir>/var/cache/fontconfig</cachedir>
      <cachedir prefix="xdg">fontconfig</cachedir>
    ...
    </fontconfig>
    

    感想

    自己既不是程序员,也不从事技术工作, arch 这个不适合新手,什么东西都要自己折腾的发行版,至今让我踩了不少坑,也学到了很多东西。

    然而……我学会这些又到底有什么用……

    12 replies    2016-03-30 12:16:06 +08:00
    shajiquan
        1
    shajiquan  
       Jan 8, 2016
    怪了,我的 mpv 正常, mplayer 却 N 久才出画面,感觉像卡死一样。甚至有时完全没出现。而且普通退出方式无效,最后只能在终端里 kill 。
    shajiquan
        2
    shajiquan  
       Jan 8, 2016
    sorry 是 linux 节点,我说的是 mac 下……
    raawaa
        3
    raawaa  
    OP
       Jan 8, 2016
    @shajiquan 对对,就是这种情况,你居然和我完全相反
    shajiquan
        4
    shajiquan  
       Jan 8, 2016
    @raawaa 我在想是不是什么东西坏了……不过没想明白。现在我只好用 VLC 。
    greenskinmonster
        5
    greenskinmonster  
       Jan 8, 2016   ❤️ 1
    mpv -vvvv 看看日志信息,卡在什么地方了。
    我的 mpv 工作的非常好。
    coolzilj
        6
    coolzilj  
       Jan 8, 2016
    借楼主宝地插个楼,你们在用类似 you-get -p mpv url 在线播放的时候,因为获取的是一串分段视频, mpv 会不会每播完一段都会卡个 1s 然后播放下一个?看着好心塞,老是以为播着播着卡住了
    Gn
        7
    Gn  
       Jan 8, 2016   ❤️ 2
    @coolzilj

    mpv 有个 --merge-files 选项,可以把分段视频当成一个文件来播放。不过在开始播放时会缓冲所有分段的开头,要等一段时间。

    另外开了这个选项最好同时指定 --cache, --cache-backbuffer 和 --cache-secs 来限制缓冲大小,因为 mpv 播放的时候所有分段都是并发缓冲的。

    具体可以看 mpv 的文档,我也是在做一个用 mpv 播放 tudou 弹幕视频的小脚本时发现的。
    也可以参考我的设置, https://github.com/Goshin/Yatto/blob/master/src/yatto.py
    coolzilj
        8
    coolzilj  
       Jan 8, 2016 via iPhone
    @Gn 我就知道是有选项的,查了半天文档,实在太多选项无从下手,谢谢你!
    raawaa
        9
    raawaa  
    OP
       Jan 9, 2016 via iPhone
    查出来了,是字体的问题,输出显示启动过程停留在 setting up fonts 好久。于是在 mpv 配置文件夹里加了个空的 fonts.conf 文件,启动起来就正常了,但是播放过程中无法显示 OSD, 心塞……
    raawaa
        10
    raawaa  
    OP
       Jan 9, 2016
    解决了, fontconfig 的问题。可能是我没有给 fontconfig 配置缓存目录的原因。在 fonts.conf 中加入 cachedir 的配置就好了。
    LINAICAI
        11
    LINAICAI  
       Mar 29, 2016
    不知道你是播放本地还是网络视频,网络视频都有延迟吧,尤其是如果用的 HLS 协议播放 m3u8 这类延迟个 10 秒都是正常的,这个是因为视频分片大小不一,单个视频分片大的话延迟相对就大了。
    raawaa
        12
    raawaa  
    OP
       Mar 30, 2016
    @LINAICAI 本地视频
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   838 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 40ms · UTC 19:50 · PVG 03:50 · LAX 12:50 · JFK 15:50
    ♥ Do have faith in what you're doing.