Skip to content

GIF

Awesome GIF Awesome

> 精选清单 GIF 资源.

与图形交换格式 (GIF) 相关的工具、脚本、库、示例和其他资源的列表.

General Tools

Utilities

  • Gifgen - 简单的高质量 GIF 编码.
  • Gifify - 将屏幕录制转换为 GIF.
  • Gifs - GIF 的存储位置.
  • Gifshot - 从 Yahoo 的媒体创建动画 GIF. (demo)
  • Gifsockets - 使用动画 GIF 作为传输的实时通信库.
  • X-gif - 用于灵活 GIF 播放的 Web 组件.
  • GifW00t - JavaScript 网络记录器.
  • gif-machine - 从 YouTube 视频创建 GIF.
  • gifstreaming - Live video streaming server.
  • Screengif - 创建动画 GIF 截屏视频.
  • vnc-over-gif - 通过 http 将屏幕更新作为动画 GIF 提供.
  • gifdeck - 将您的 SlideShares 转换为动画 GIF.
  • Gifbot - GIF 搜索 Slack.
  • Gif-camera - 使用网络摄像头创建动画 GIF.
  • Gifline - 将 GIF 放入您的电子邮件中的 Chrome 扩展.
  • Gifdrop - 为您的 GIF 图像集合创建存储库.
  • Gh-gif - NodeGH 插件,用于使用 GIF 反应评论拉取请求/问题.
  • Tty2gif - 将脚本及其输出记录为二进制和 GIF 格式.
  • Giftoppr - 将您最喜爱的 GIF 与 Dropbox 同步.
  • Gifit - 从 YouTube 视频制作 GIF 的 Chrome 扩展.
  • Ccapture.js - 捕获使用 HTML5 画布创建的动画.
  • Kap - 漂亮的开源应用程序,可捕获您的屏幕并导出为 GIF.
  • Gifit (the other one) - 在 stdout 的降价中获取搜索结果 giphy GIF,ala $ gifit kittens.
  • gifski - 基于 libimagequant 的高质量 GIF 编码器.
  • Gifcurry - 为 GIF 制作者打造的开源 Haskell 编辑器.

Libraries

ActionScript

C++

  • Node-gif - 制作 GIF 的 C++ 库.
  • Gif-h - 用于创建动画 GIF 的 C++ 单头库.
  • msf_gif - 用于创建动画 GIF 的 C/C++ 单头文件库.

C#

- [dot-screencap](https://github.com/Speiser/dot-screencap) - 一个简单的库来记录您的屏幕并将其保存为动画 GIF. - [WpfAnimatedGif](https://github.com/XamlAnimatedGif/WpfAnimatedGif) - 在 WPF 中显示动画 GIF 图像的简单库. - [XamlAnimatedGif](https://github.com/XamlAnimatedGif/XamlAnimatedGif) - 在 XAML 应用程序(WPF、WinRT、Windows Phone)中显示动画 GIF 图像的简单库. - [AnimatedGif](https://github.com/mrousavy/AnimatedGif) - 用于读取和创建动画 GIF 的高性能 .NET 库. ### Haxe - [Gif](https://github.com/snowkit/gif) - Haxe GIF 编码器. ### Java - [Android-gif-drawable](https://github.com/koral--/android-gif-drawable) - 用于在 Android 上显示动画 GIF 的视图和可绘制对象. - [gifanimateddrawable](https://github.com/Hipmob/gifanimateddrawable) - 使用动画 GIF 作为 Android Drawable. - [GifView](https://github.com/RoiSoleil/GifView) - 处理 GIF 的 Android 库. - [Gif Movie View](https://github.com/sbakhtiarov/gif-movie-view) - 用于显示 GIF 动画的 Android 视图小部件. - [GifImageView](https://github.com/felipecsl/GifImageView) - 处理动画 GIF 图像的 Android ImageView. - [Gif-animation](https://github.com/extrapixel/gif-animation) - 播放和导出 GIF 的处理库. - [Android-gif-encoder](https://github.com/nbadal/android-gif-encoder) - 适用于 Android 的动画 GIF 编码器. - [GIFDroid](https://github.com/curtislarson/GIFDroid) - Android 视频到 GIF 转换器. - [Android-GifStitch](https://github.com/CaptPhunkosis/Android-GifStitch) - 创建和分享动画 GIF. ### JavaScript - [Gif.js](https://github.com/jnordberg/gif.js) - 从 DOM 创建 GIF. - [Omggif](https://github.com/deanm/omggif) - GIF 89a 编码器和解码器. - [Animated_GIF](https://github.com/sole/Animated_GIF) - 用于创建动画 GIF 的 JavaScript 库. - [Gifffer](https://github.com/krasimir/gifffer) - 防止动画 GIF 自动播放的 JavaScript 库. - [Gifplayer](https://github.com/rubentd/gifplayer) - 用于播放和停止动画 GIF 的 JQuery 插件. - [Jsgif](https://github.com/shachaf/jsgif) - JavaScript GIF 解析器和播放器. - [node-gify](https://github.com/tj/node-gify) - JavaScript 使用 ffmpeg 和 gifsicle 将视频转换为 GIF. - [Gifencoder](https://github.com/eugeneware/gifencoder) - 为 Node.js 生成服务器端动画 GIF. - [Gif-video](https://github.com/hughsk/gif-video) - JavaScript 将 GIF 图像转换为支持 HTML5 的视频. - [Gif-player](https://github.com/apankrat/gif-player) - JavaScript 中的点播 GIF 加载器/播放器. - [GifgifLab-face](https://github.com/Viral-MediaLab/gifgifLab-face) - 面部情绪检测器. - [node-youtube](https://github.com/javascipt/node-youtube) - YouTube 到快照和 GIF. ### PHP - [GifCreator](https://github.com/Sybio/GifCreator) - 从多个图像创建动画 GIF 的 PHP 类. - [Spacer.gif](https://github.com/msng/spacer.gif) - 提供 spacer.gif 1x1 的 PHP 脚本. - [GifFrameExtractor](https://github.com/Sybio/GifFrameExtractor) - 分隔动画 GIF 的所有帧的 PHP 类. ### Objective-C - [UIimage from GIF](https://github.com/mayoff/uiimage-from-animated-gif) - 加载动画 GIF 的 UIImage 类别. - [GIFRefreshControl](https://github.com/cyndibaby905/GIFRefreshControl) - “Twitter 音乐”和“Yahoo! Weather”等下拉刷新控件. - [UIImageView-PlayGIF](https://github.com/yfme/UIImageView-PlayGIF) - 用于播放 GIF 的 UIImageView 类别/子类. - [FLAnimatedImage](https://github.com/Flipboard/FLAnimatedImage) - FlipBoard 的 iOS GIF 引擎. - [Animated-GIF-iPhone](https://github.com/arturogutierrez/Animated-GIF-iPhone) - 支持 iOS 上的动画 GIF. - [UzysAnimatedGifPullToRefresh](https://github.com/uzysjung/UzysAnimatedGifPullToRefresh) - PullToRefresh 使用动画 GIF 到任何滚动视图. - [SvGifView](https://github.com/smileEvday/SvGifView) - iOS 加载和显示 GIF. - [GifHUD](https://github.com/cemolcay/GiFHUD) - 仅显示动画 GIF 图像的 iOS 进度 HUD. - [Video-Background GIF](https://github.com/ElvinJin/Video-Background-GIF) - iOS 视频背景 GIF. - [AnimatedGifExample](https://github.com/kasatani/AnimatedGifExample) - iOS 动画和透明 GIF. ### Swift - [SwiftyGif](https://github.com/kirualex/SwiftyGif) - 高性能且易于使用的 Gif 引擎. - [Gifu](https://github.com/kaishin/gifu) - Swift 中对 iOS 的动画 GIF 支持. ## GUI - [Glyph](http://www.glyph.video/) - 用于从视频生成无缝循环 GIF 和动态图片的工具. - [Qgifer](https://sourceforge.net/projects/qgifer/) - [GifPro](https://github.com/unixpickle/GifPro) - 适用于 Mac 的 GIF 编码器. ## Hosting - [Gfycat](https://gfycat.com) - 最大 GIF/视频长度:15 秒. 最大文件上传为 300Mb. - [Imgur](https://imgur.com) - 最大文件上传为 50MB. ## Online Tools - [Vid2gif](https://imgur.com/vidgif) - imgur 将视频转为 GIF. - [EzGif](https://ezgif.com/) - 在线 GIF 制作器和图像编辑器. - [Giflr](https://giflr.com/) - 用于制作或重新混合动画 GIF 的网络应用程序. ## Community - [Giphy.com](https://giphy.com) - [/r/educationalgifs](https://www.reddit.com/r/educationalgifs/) ## Scripts ### Frames to GIF FFmpeg
ffmpeg -f image2 -i image%d.jpg 动画.gif
Imagemagick
转换 -delay 20 -loop 0 frames*.png animated.gif
用于 GraphicsMagick、ImageMagick、FFmpeg 的 Bash 脚本(```frames2gif.sh''`)
#!/bin/bash
if [ $# -ne 5 ]; then
    echo "请提供电影名称和存储帧的目录"
    echo "./frames2gif.sh [目录] [movie.mp4] [文件名.gif] [gm|im|ffmpeg] [png|jpg]"
    出口 1
fi
    如果 [ "png" == "$5" ]; 然后
        后缀=“PNG”
            后缀=“jpg”
        CONVERT=$(哪个转换)
    通用汽车=$(哪个通用汽车)
    FFMPEG=$(哪个ffmpeg)
    FFPROBE=$(哪个 ffprobe)
    FPS=$($FFPROBE -show_streams -select_streams v -i "$2" 2>/dev/null | grep "r_frame_rate" | cut -d'=' -f2 | cut -d'/' -f1)
    回声“每秒帧数:${FPS}if [ "im" == "$4" ]; then # use imagemagick
    FPS=$(echo "1 / ${FPS} * 100" |bc -l)
    $CONVERT "$1/*.${suffix}" -delay ${FPS} -loop 0 "$3"
elif [ "gm" == "$4" ]; then # use graphicsmagick
    FPS=$(echo "1 / ${FPS} * 100" |bc -l)
    $GM convert "$1/*.${suffix}" -delay ${FPS} -loop 0 "$3"
else # use crappy gif-algorithm from ffmpeg
    $FFMPEG -f image2 -framerate ${FPS} -i "$1/%08d.${suffix}" "$3"
fi
From [DeepDreamVideo](https://github.com/graphific/DeepDreamVideo), [source](https://github.com/graphific/DeepDreamVideo/blob/master/frames2gif.sh) ### GIF to frames
ffmpeg -i video.mpg 图片%d.jpg
转换 -coalesce animated.gif image%05d.png
### High quality GIF 使用 ffmpeg / 基于此 [article](http://blog.pkh.me/p/21-high-quality-gif-with-ffmpeg.html) - 生成调色板:
#!/bin/sh
start_time=30
duration=3
ffmpeg -y -ss $start_time -t $duration -i input.avi \
-vf fps=10,scale=320:-1:flags=lanczos,palettegen palette.png
- 使用调色板输出 GIF:
#!/bin/sh
start_time=30
duration=3
ffmpeg -ss $start_time -t $duration -i input.avi -i palette.png -filter_complex \
"fps=10,scale=320:-1:flags=lanczos[x];[x][1:v]paletteuse" output.gif
### Optimize GIF
convert -layers 优化 output.gif output_optimized.gif
### Lossy GIF Compressor
./gifsicle -O3 --lossy=80 -o lossy-compressed.gif input.gif
[Lossy Gif](https://kornel.ski/lossygif) ### Making GIF from video
 moviepy.editor 导入 *

剪辑 = (VideoFileClip("input.avi")
        .subclip((4,00.00),(5,00.00))
        .resize(0.3))
clip.write_gif("output.gif")
[article](http://zulko.github.io/blog/2014/01/23/making-animated-gifs-from-video-files-with-python/#converting-a-video-excerpt-into-a-gif) ### Cinemagraphs 冻结区域
 moviepy.editor 导入 *

剪辑 = (VideoFileClip("input.avi")
        .subclip((4,00.00),(5,00.00))
        .resize(0.3)
        .fx(vfx.freeze_region, outside_region=(170, 230, 380, 320)))
clip.write_gif("输出.gif", fps=15)
[article](http://zulko.github.io/blog/2014/01/23/making-animated-gifs-from-video-files-with-python/#freezing-a-region)
ffmpeg \
-ss ${starttime} -t ${duration} -i ${vidfile}                         `# body of loop` \
-ss TODO ${starttime} MINUS ${duration} -t ${fadetime} -i ${vidfile}  `# lead-in for crossfade` \
-loop 1 -i ${stillfile}                                               `# masked still image` \
-filter_complex“
  [0:v]setpts=PTS-STARTPTS[vid];                                      `# speed adjustment - not needed here, so noop`
  color=white,scale=3840x2160,fade=in:st=0:d=${fadetime}[alpha];      `# crossfade alpha, double length ahead of speed change`
  [1:v][alpha]alphamerge[am];                                         `# apply alpha to lead-in`
  [am]setpts=PTS+(${duration}-${fadetime})/TB[layer2];                  `# speed adjustment and offset for lead-in`
  [vid][layer2]overlay[oo];                                           `# overlay for crossfade`
  [oo][2:v]overlay=shortest=1[out1];                                  `# overlay still image`
  [out1]crop=w=${cropfactor}*iw:h=${cropfactor}*ih:y=${yoffset}*ih,scale=${outputwidth}:-1, `# crop and scale`
  eq=gamma=${gamma}:contrast=${contrast}:saturation=${saturation},unsharp                   `# final adjustments`
“-一个输出.mp4
### Perfect Loop
 moviepy.editor 导入为 mp
 moviepy.video.tools.cuts 导入 FramesMatches

clip = mp.VideoFileClip("input.avi").resize(0.3)
场景 = FramesMatches.from_clip(clip, 10, 3)

selected_scenes = scenes.select_scenes(2, 1, 4, 0.5)
selected_scenes.write_gifs(clip.resize(width=450), "./outputs_directory")
[article](http://zulko.github.io/blog/2015/02/01/extracting-perfectly-looping-gifs-from-videos-with-python-and-moviepy/) ### YouTube video to GIF - 通过 youtube-dl 下载然后转换.
youtube-dl https://www.youtube.com/watch?v=V2XpsaLqXc8
[Youtube-dl](https://rg3.github.io/youtube-dl/) ### Grabbing each frame of an HTML5 Canvas Using [PhantomJS](https://phantomjs.org). 以此为例 [canvas](http://www.effectgames.com/demos/canvascycle/?sound=0).
var webPage = require('网页');
var fs = require('fs');
var page = webPage.create();

变种 NB_FRAME = 100;
无功电流= 0;

page.open('http://www.effectgames.com/demos/canvascycle/?sound=0',
功能状态{
  如果状态===成功”){
      无功电流= 0;
      var grabber = setInterval(函数(){
          var frame = page.evaluate(函数() {
           返回 document.getElementById('mycanvas').toDataURL("image/png").split(",")[1];
          });
          fs.write("./frame-" + current + ".png",atob(frame), 'wb');
      如果++当前=== NB_FRAME{
         window.clearInterval抓取器);
         phantom.exit(0);
      }
    }, 1000);
  }
});
## Miscellaneous - [Why is the GIF I created so slow?](https://superuser.com/questions/569924/why-is-the-gif-i-created-so-slow/569967) - 使用ImageMagick 解决GIF 速度问题. ## Use 使用此列表的最佳方法是: - 通过浏览 [contents](#contents). - 通过使用command + F来搜索内容 ## Credits By [Craig Davison](https://davison.io) 和贡献者. 基于 [recovered list](https://github.com/sindresorhus/awesome/issues/872) 经过 [Ismail Baaj](https://ismailbaaj.fr).