FFmpeg 視頻轉(zhuǎn)高質(zhì)量 gif 圖輸出方案對比

不好意思腹殿,這里先安利下自己最近上架的應(yīng)用独悴,因?yàn)檫@個(gè) App 使用了本篇文章中提到的技術(shù)方案進(jìn)行了實(shí)現(xiàn),實(shí)際效果歡迎大家直接去 Google Play 或國內(nèi)酷安市場下載安裝試試锣尉,歡迎拍磚刻炒。
VEditor - Google Play
VEditor - 酷安

使用 ffmpeg 視頻文件轉(zhuǎn) gif 輸出時(shí),需要壓縮 gif 輸出自沧,參考文章使用 ffmpeg 實(shí)現(xiàn) MP4 與 GIF 的互轉(zhuǎn) 可以進(jìn)行基本的處理坟奥。但是看到使用 FFmpeg 處理高質(zhì)量 GIF 圖片 這篇文章中闡述了一些提升方案。按照文章中說的方案進(jìn)行了處理拇厢,下面是對比使用普通方案的效果爱谁。

原理介紹的英文原文:High quality GIF with FFmpeg

原理(參考原文中的描述)

GIF 是受限于256色調(diào)色板。并且默認(rèn)情況下孝偎,F(xiàn)Fmpeg 只使用一個(gè)通用調(diào)色版去嘗試覆蓋所有的顏色區(qū)域访敌,以此來支持含有大量內(nèi)容的文件。

普通轉(zhuǎn)換為GIF的效果圖

提高 GIF 圖片質(zhì)量的第一步就是定義一個(gè)更好的調(diào)色板邪媳。GIF格式存儲了一個(gè)全局調(diào)色板捐顷,但你可以對一張圖片重新定義一個(gè)調(diào)色板。

每一幀的調(diào)色板都可以取代全局調(diào)色板來只對一幀起作用雨效。一旦你停止定義一個(gè)調(diào)色板迅涮,它將會回落到全局調(diào)色板。

因此先考慮為gif生成一個(gè)新的調(diào)色板徽龟,第一次遍運(yùn)行是對整個(gè)圖片計(jì)算一個(gè)調(diào)色板叮姑,這就是新的 palettegen 濾波器參與進(jìn)來的地方。
這個(gè)濾波器對每一幀的所有顏色制作一個(gè)直方圖,并且基于這些生成一個(gè)調(diào)色板传透。這個(gè)濾波器是在做色彩量化耘沼,并且生成一個(gè)調(diào)色板(通常保存在一個(gè)PNG文件里)

生成全局調(diào)色板

提升gif質(zhì)量的第二步是解決顏色映射與抖動(dòng)。
生成全局調(diào)色板后朱盐,第二步就是將顏色效果映射到顏色輸出流中群嗤,這個(gè)是通過 paletteuse 濾波器完成的。它將會使用這個(gè)調(diào)色板來生成最終的量化顏色流兵琳,它的任務(wù)是在生成的調(diào)色板中找出最合適的顏色來表示輸入的顏色狂秘。
這個(gè)濾波器也是你可以選擇使用哪種抖動(dòng)方法的地方,抖動(dòng)可以讓圖片更加清晰躯肌。使用這兩個(gè)濾波器效果后可以讓你將 GIF 編碼成單全局調(diào)色板者春、抖動(dòng)的。

關(guān)于抖動(dòng)清女,是指把圖像從較高色彩深度(即可用的顏色數(shù))向較低色彩深度的區(qū)域繪制時(shí)钱烟,在圖像中有意地插入噪點(diǎn),通過有規(guī)律地?cái)_亂圖像來讓圖像對于肉眼更加真實(shí)的做法嫡丙。對于圖像降低色彩深度繪制時(shí)拴袭,可以避免出現(xiàn)大片的色帶與色塊,借以提升實(shí)際觀感效果迄沫。

進(jìn)行高質(zhì)量輸出優(yōu)化后的效果

實(shí)際測試環(huán)境

平臺: Nexus 5X
操作系統(tǒng): Android 7.1.1
視頻原文件: demo.mp4
FFmpeg庫: 自編譯支持 Android 平臺的 ffmpeg 的 so 包

普通方案下的處理

1.執(zhí)行命令

普通方案生成 gif
@param startTime 開始時(shí)間 秒/s
@param duration  間隔時(shí)間 秒/s(用來截取視頻)
@param videoPath 源視頻路徑
@param outFilePath Gif輸出路徑
String command = "ffmpeg -ss " + startTime + " -t " + duration + " -i " + videoPath + " -r 15 -vf fps=15,scale=270:-1 " + outFilePath;

2.輸出效果圖

demo_mp4_1499666734.gif

3.實(shí)際運(yùn)行 Log 日志

普通視頻轉(zhuǎn)GIF方案執(zhí)行耗時(shí) 5349 ms
輸出文件大械狙铩:2,649,453 字節(jié)
尺寸:480?×?270
07-10 14:10:45.360 5355-5355/gdut.bsx.videoreverser D/VideoReverser: cmdGif videoPath:/storage/emulated/0/demo.mp4
07-10 14:10:45.361 5355-5355/gdut.bsx.videoreverser D/VideoReverser: cmdGif outFilePath:/storage/emulated/0/VideoReverser/demo_mp4_1499667045.gif
07-10 14:10:45.361 5355-5355/gdut.bsx.videoreverser D/VideoReverser: cmdGif startTime:2 duration: 11
07-10 14:10:45.369 5355-5355/gdut.bsx.videoreverser D/VideoReverser: cmdGif Command:ffmpeg -ss 2 -t 11 -i /storage/emulated/0/demo.mp4 -s 480*270 -b 568k -r 10 -pix_fmt rgb24 -f gif /storage/emulated/0/VideoReverser/demo_mp4_1499667045.gif
07-10 14:10:45.371 5355-5355/gdut.bsx.videoreverser D/VideoReverser: cmdGif Command onBegin
07-10 14:10:47.208 5355-5355/gdut.bsx.videoreverser D/VideoReverser: onCompletion
07-10 14:10:50.709 5355-5355/gdut.bsx.videoreverser D/VideoReverser: cmdGif Command onEnd0
07-10 14:10:50.709 5355-5355/gdut.bsx.videoreverser D/VideoReverser: cmdGif 耗時(shí):5349

GIF高質(zhì)量優(yōu)化方案

1.創(chuàng)建全局調(diào)色板

生成全局調(diào)色板命令:
@param startTime 開始時(shí)間 秒/s
@param duration  間隔時(shí)間 秒/s(用來截取視頻)
@param videoPath 源視頻路徑
@param globalPalettePicPath 輸出的全局調(diào)色板的路徑
String command = "ffmpeg -ss " + startTime + " -t " + duration + " -i " + videoPath + " -b 568k -r 20 -vf fps=20,scale=320:-1:flags=lanczos,palettegen -y " + globalPalettePicPath;

輸出的全局調(diào)色板圖片:

全局調(diào)色板圖片.png

2.輸出優(yōu)化后的 gif

利用調(diào)色板圖片和視頻源文件同時(shí)處理生成 gif 命令:
@param startTime 開始時(shí)間 秒/s
@param duration  間隔時(shí)間 秒/s(用來截取視頻)
@param videoPath 源視頻路徑
@param globalPalettePicPath 全局調(diào)色板的路徑
@param outFilePath Gif輸出路徑
String command = "ffmpeg -v warning -ss " + startTime + " -t " + duration + " -i " + videoPath + " -i " + globalPalettePicPath + " -r 15 -lavfi fps=15,scale=270:-1:flags=lanczos[x];[x][1:v]paletteuse -y " + outFilePath;

輸出最終 gif 圖片:

demo_mp4_1499666734.gif

3.實(shí)際日志輸出

執(zhí)行耗時(shí): 16931 ms
輸出文件大小:2,951,864 字節(jié)
尺寸:320?×?180
07-10 14:05:34.327 2557-2557/gdut.bsx.videoreverser D/VideoReverser: cmdGif videoPath:/storage/emulated/0/demo.mp4
07-10 14:05:34.328 2557-2557/gdut.bsx.videoreverser D/VideoReverser: cmdGif outFilePath:/storage/emulated/0/VideoReverser/demo_mp4_1499666734.gif
07-10 14:05:34.328 2557-2557/gdut.bsx.videoreverser D/VideoReverser: cmdGif startTime:2 duration: 11
07-10 14:05:34.328 2557-2557/gdut.bsx.videoreverser D/VideoReverser: cmdGif Command:ffmpeg -v warning -ss 2 -t 11 -i /storage/emulated/0/demo.mp4 -r 10 -vf fps=10,scale=320:-1:flags=lanczos,palettegen -y /storage/emulated/0/VideoReverser/demo_mp4_1499666734.png
07-10 14:05:34.332 2557-2557/gdut.bsx.videoreverser D/VideoReverser: cmdGif Command onBegin
07-10 14:05:42.973 2557-2557/gdut.bsx.videoreverser D/VideoReverser: cmdGif Command:ffmpeg -v warning -ss 2 -t 11 -i /storage/emulated/0/demo.mp4 -i /storage/emulated/0/VideoReverser/demo_mp4_1499666734.png -r 10 -lavfi fps=10,scale=320:-1:flags=lanczos[x];[x][1:v]paletteuse -y /storage/emulated/0/VideoReverser/demo_mp4_1499666734.gif
07-10 14:05:51.258 2557-2557/gdut.bsx.videoreverser D/VideoReverser: cmdGif Command onEnd0
07-10 14:05:51.258 2557-2557/gdut.bsx.videoreverser D/VideoReverser: cmdGif 耗時(shí):16931

總結(jié)

對于 gif 的處理要考慮好媒體文件的相關(guān)特性羊瘩,不論是從分辨率、幀率或采樣率等都需要仔細(xì)考慮產(chǎn)品的需求依賴盼砍。要對文件圖像質(zhì)量和文件大小等方面綜合考慮尘吗,以實(shí)際觀感出發(fā),確定文件合適的操作依據(jù)浇坐。

再安利一波

最近自己開發(fā)的這個(gè) App 按照了本篇文章中提到的技術(shù)方案進(jìn)行了實(shí)現(xiàn)睬捶,實(shí)際效果大家直接去 Google Play 或國內(nèi)酷安市場下載安裝試試,歡迎拍磚近刘。
VEditor - 酷安
VEditor - Google Play

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末擒贸,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子觉渴,更是在濱河造成了極大的恐慌介劫,老刑警劉巖,帶你破解...
    沈念sama閱讀 210,978評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件案淋,死亡現(xiàn)場離奇詭異座韵,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,954評論 2 384
  • 文/潘曉璐 我一進(jìn)店門誉碴,熙熙樓的掌柜王于貴愁眉苦臉地迎上來宦棺,“玉大人,你說我怎么就攤上這事黔帕〈蹋” “怎么了?”我有些...
    開封第一講書人閱讀 156,623評論 0 345
  • 文/不壞的土叔 我叫張陵成黄,是天一觀的道長呐芥。 經(jīng)常有香客問我,道長慨默,這世上最難降的妖魔是什么贩耐? 我笑而不...
    開封第一講書人閱讀 56,324評論 1 282
  • 正文 為了忘掉前任,我火速辦了婚禮厦取,結(jié)果婚禮上潮太,老公的妹妹穿的比我還像新娘。我一直安慰自己虾攻,他們只是感情好铡买,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,390評論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著霎箍,像睡著了一般奇钞。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上漂坏,一...
    開封第一講書人閱讀 49,741評論 1 289
  • 那天景埃,我揣著相機(jī)與錄音,去河邊找鬼顶别。 笑死谷徙,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的驯绎。 我是一名探鬼主播完慧,決...
    沈念sama閱讀 38,892評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼剩失!你這毒婦竟也來了屈尼?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,655評論 0 266
  • 序言:老撾萬榮一對情侶失蹤拴孤,失蹤者是張志新(化名)和其女友劉穎脾歧,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體乞巧,經(jīng)...
    沈念sama閱讀 44,104評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡涨椒,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蚕冬。...
    茶點(diǎn)故事閱讀 38,569評論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡免猾,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出囤热,到底是詐尸還是另有隱情猎提,我是刑警寧澤,帶...
    沈念sama閱讀 34,254評論 4 328
  • 正文 年R本政府宣布旁蔼,位于F島的核電站锨苏,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏棺聊。R本人自食惡果不足惜伞租,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,834評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望限佩。 院中可真熱鬧葵诈,春花似錦、人聲如沸祟同。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,725評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽晕城。三九已至泞坦,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間砖顷,已是汗流浹背贰锁。 一陣腳步聲響...
    開封第一講書人閱讀 31,950評論 1 264
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留滤蝠,地道東北人李根。 一個(gè)月前我還...
    沈念sama閱讀 46,260評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像几睛,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子粤攒,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,446評論 2 348

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 171,734評論 25 707
  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫所森、插件、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 12,058評論 4 62
  • 版本記錄 前言 xcode有很多基礎(chǔ)配置夯接,這里很雜很細(xì)焕济,需要大家很細(xì)心的注意,并不難盔几,但是這里的基礎(chǔ)配置的設(shè)置無疑...
    刀客傳奇閱讀 10,150評論 11 13
  • 4-29晚上的火車晴弃,武漢-北京。30號到,第二次來到北京上鞠,4個(gè)人际邻。帶著項(xiàng)目,帶上好心情芍阎,下火車世曾,就忙著訂酒店。于是...
    Themores閱讀 232評論 0 4
  • 借我十年 借我亡命天涯的勇敢 借我說的出口的淡淡誓言 借我殺死庸碌的情懷 借我一個(gè)美好的地方
    新鮮的陽光_1364閱讀 277評論 0 0