平时爱折腾多媒体方面的东西,对多媒体多少也有一点了解,下面分享一些 Linux 多媒体应用的见解,不足之处欢迎大家指正。

本文的组织如下:前面是对整体情况的一些介绍,后面就是具体的应用了。

多媒体文件结构介绍

音视频流

音视频流是多媒体文件的核心数据。

文件容器

音视频流封装在文件里的方式。

编码

音视频流如果以原始编码的方式存储,将需占用巨大的空间,为此需要编码以达到压缩的目的。

Linux 的多媒体框架

GStreamer

成熟,LGPL,因而被广泛使用。可以使用 gstreamer-ffmpeg,还有 gstreamer-pitfdll 来使用 Windows 的 Direct Show 滤镜(win32codecs)。GNOME 下有著名的前端 Totem。

Xine

另一个多媒体框架,GPL。曾经的亮点是可以 wrapper Windows 的 DirectShow 滤镜(win32codecs)。

Mplayer/Mencoder

完整的多媒体平台。Mplayer 是一个播放器,Mencoder 是一个非常有名的转码器,Windows 下很多转码工具其实都是它的前端。因为 Mplayer 主要是作为一个播放器,所以其对影音源的读取能力很强,包括各种 DVD 和蓝光 DVD。通常,即使你使用 ffmpeg 制作 DVDRip,也需要使用 Mplayer 来先将影音流 dump 出来。

VLC

完整统一的多媒体平台。与 Mplayer 一样同时支持编解码和播放,同时对流媒体支持非常好,甚至用来在线播放 ftp 里的电影都非常稳定,可以作为流媒体服务器。VLC 提供了一个完整的框架,但是由于年纪轻,文档少,一些功能还有不稳定的因素,因此现在还不是最完美的方案,但我们有理由相信,也许将来 VLC 将成为主流的跨平台播放器。

XMMS2

精炼的音频播放框架。命令行参数十分友好,而且是以后台 daemon 的方式运行,因此是个非常好的命令行音乐播放器。

FFmpeg

通用的转码平台,大牛 Fabrice Bellard 发起的项目,libavcodec 就是其中最重要的一个组件,实际上上边很多播放器强大的解码能力都是由此项目提供的。ffmpeg 可以支持 copy,可以用来从影片里提取声音,或者切割多媒体文件。由于它是作为一个转码平台,能够输出许多容器格式,因此在提取和切割方面十分强大。

HandBrake

针对视频收藏分享的转码平台,能够使用 x264 和 xvid 两种编码器,并最后封装成强大的 mkv 格式。各平台下都有相应的版本;GUI 和 CLI 接口十分友好,参数设置方便,且可以从 GUI 生成命令行参数。

Linux 的编解码器

神级的解码器 libavcodec

FFmpeg 中最重要的部分,对 i386 和 arm 指令集优化极高,遗憾地是现在对多核的支持还比较早期。

昔日王者的编码器 xvid

当年 DVD Rip 的事实标准格式。据说是 MPEG4 标准的一个实现,很多便携 MP4 都支持这种格式(通常是用 avi 封装)。

前沿编码器 x264

h264 编码器的一个实现,现在几乎所有的高清电影都用这种格式和该编码器编码,将来应该会更加流行;普清视频也有用这种编码器编码,通常称为 half cd,以提供较好的压缩率。而且 h264 的软硬件解码已十分完善,很多显卡也支持 h264 硬件解码,同时也有可以接受的软件解码库。所以无论从压缩质量还是兼容性来说,都可以使用它来编码你的收藏视频。ffmpeg 和 mencoder 都有 x264 支持,只要在编译时开启了相应选项,就能直接在其中方便地使用 x264。

解流与混流

mkvtoolnix

MKV 的推动者,最完美的 MKV 解决方案。可以从 GUI 生成命令行参数。

用 Mplayer 看影片

Mplayer 非常强大,不仅对 ffmpeg 的 libavcodec 支持非常好,还能调用各种外部的解码库;缺点是没有好用的 GUI 前端,Gnome Mplayer 还不错,但是还是有些不足的细小地方,但是 Mplayer 的 CLI 是非常强大的。下面介绍~/.mplayer/config 文件的配置。

顺便再提一个很 shit 的问题:如果你用的是 A 卡+fglrx 的驱动,你需要使用 gl 模式的输出,原因如下:

Catalyst’s Xv implementation is broken (visual glitches, no vsync, wrong colors.) Xv with Catalyst is supposed to only have correct colors when you connect your card to a TV

无语了,不得不承认 M$ PC 机本来就不是为 Linux 设计的,在 M$ PC 机诞生之初,在 M$ PC 里装 Linux 是非法的。就好像现在刷路由器和手机一样,只不过现在只是保修没了而已。

设置编解码器和输出设备

vfm="ffmpeg"
afm="ffmpeg"
vo=xv
ao=alsa

设置字幕

fontconfig=yes
font='WenQuanYi Micro Hei'
# ass-hinting=0
# ass-styles=
sub-fuzziness=1
slang=Chinese,chs,zh
subfont-text-scale=2
subfont-osd-scale=2
subpos=95
subcp='enca:zh:cp936'

关闭屏幕保护

heartbeat-cmd="gnome-screensaver-command -p"

用 ffmpeg 录屏

ffmpeg -f x11grab -q 2 -r 15

用 HandBrake 转码

HandBrake 本来主要是针对 DVD 收藏的,但由于其使用的解码前端是 libavcodec,而现在 libavcodec 几乎已经支持所有格式,所以 HandBrake 已经可以作为一个通用的转码工具,输出编码是非常适合收藏的 h264 或 xvid。我相机拍下来的影像都是用它来转码的。

HandBrake 的操作是图形界面的,与普通的转码软件差不多,很容易适应,这里就不做赘述了。

更新时间: