mpv 播放视频要好久才出画面 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
Distributions
Ubuntu
Fedora
CentOS
中文资源站
网易开源镜像站
raawaa
V2EX    Linux

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

  •  
  •   raawaa
    raawaa 2016-01-08 09:35:56 +08:00 5690 次点击
    这是一个创建于 3631 天前的主题,其中的信息可能已经有所发展或是发生改变。
    好奇怪的问题,不报任何错误,但是刚开始只有窗口没有任何画面,等了好久……视频画面出来了。

    用 mplayer 的话就没有问题。
    第 1 条附言    2016-01-09 21:26:49 +08:00

    帖一下解决方案

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

    我的机器是 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 条回复    2016-03-30 12:16:06 +08:00
    shajiquan
        1
    shajiquan  
       2016-01-08 11:15:33 +08:00
    怪了,我的 mpv 正常, mplayer 却 N 久才出画面,感觉像卡死一样。甚至有时完全没出现。而且普通退出方式无效,最后只能在终端里 kill 。
    shajiquan
        2
    shajiquan  
       2016-01-08 11:15:58 +08:00
    sorry 是 linux 节点,我说的是 mac 下……
    raawaa
        3
    raawaa  
    OP
       2016-01-08 11:17:09 +08:00
    @shajiquan 对对,就是这种情况,你居然和我完全相反
    shajiquan
        4
    shajiquan  
       2016-01-08 11:24:54 +08:00
    @raawaa 我在想是不是什么东西坏了……不过没想明白。现在我只好用 VLC 。
    greenskinmonster
        5
    greenskinmonster  
       2016-01-08 11:31:24 +08:00   1
    mpv -vvvv 看看日志信息,卡在什么地方了。
    我的 mpv 工作的非常好。
    coolzilj
        6
    coolzilj  
       2016-01-08 12:38:01 +08:00
    借楼主宝地插个楼,你们在用类似 you-get -p mpv url 在线播放的时候,因为获取的是一串分段视频, mpv 会不会每播完一段都会卡个 1s 然后播放下一个?看着好心塞,老是以为播着播着卡住了
    Gn
        7
    Gn  
       2016-01-08 13:12:14 +08:00   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  
       2016-01-08 13:23:51 +08:00 via iPhone
    @Gn 我就知道是有选项的,查了半天文档,实在太多选项无从下手,谢谢你!
    raawaa
        9
    raawaa  
    OP
       2016-01-09 09:55:29 +08:00 via iPhone
    查出来了,是字体的问题,输出显示启动过程停留在 setting up fonts 好久。于是在 mpv 配置文件夹里加了个空的 fonts.conf 文件,启动起来就正常了,但是播放过程中无法显示 OSD, 心塞……
    raawaa
        10
    raawaa  
    OP
       2016-01-09 15:18:29 +08:00
    解决了, fontconfig 的问题。可能是我没有给 fontconfig 配置缓存目录的原因。在 fonts.conf 中加入 cachedir 的配置就好了。
    LINAICAI
        11
    LINAICAI  
       2016-03-29 02:51:12 +08:00
    不知道你是播放本地还是网络视频,网络视频都有延迟吧,尤其是如果用的 HLS 协议播放 m3u8 这类延迟个 10 秒都是正常的,这个是因为视频分片大小不一,单个视频分片大的话延迟相对就大了。
    raawaa
        12
    raawaa  
    OP
       2016-03-30 12:16:06 +08:00
    @LINAICAI 本地视频
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     2890 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 34ms UTC 14:13 PVG 22:13 LAX 06:13 JFK 09:13
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86