Skip to content
This repository was archived by the owner on Aug 9, 2021. It is now read-only.
/ godot-gifexporter Public archive

GDNative plugin adding a GifExporter node that enables GIF file export to Godot Engine 3.2

License

Notifications You must be signed in to change notification settings

novhack/godot-gifexporter

Folders and files

NameName
Last commit message
Last commit date

Latest commit

dff91ed · Aug 5, 2020

History

17 Commits
May 17, 2020
Apr 2, 2020
Apr 2, 2020
Jun 13, 2020
Apr 2, 2020
Apr 2, 2020
Apr 1, 2020
Aug 5, 2020
May 17, 2020
Apr 2, 2020
May 16, 2020

Repository files navigation

godot-gifexporter

This plugin is now depracated in favor of pure GDScript implementation by jegor377 https://github.com/jegor377/godot-gdgifexporter

Plugin adding a GifExporter singleton enabling export of Image objects as a GIF file. Currently supports Windows and Linux, both 32 and 64 bit.

Installation:

  1. Clone this repository into your Godot projects addons folder - GDNative builds are already included in the repository.
  2. Enable this plugin in Project Settings.
  3. A new node GifExporter will now become available.

Usage:

First create a new instance of GifExport node. Then you can call these methods:

  1. Starts gif export:

GifExporter.begin_export(filename: String, width: int, height: int, frame_delay: float, loop_count: int = 0, bit_depth: int = 8, dither: bool = false) -> bool

  • filename - full path with a filename ('/home/user/anim.gif')
  • width, height - default frame dimmensions
  • frame_delay - default delay between animation frames
  • loop_count - how many times is animation repeated - 0 is infinite
  • bit_depth - default frame color bit depth
  • dither - default apply dithering algorithm to frames

The function returns false if it's called on an unsupported platform, true otherwise.

  1. Adds a frame to gif:

GifExporter.write_frame(frame : Image, background_color : Color, frame_delay : float, bit_depth : int = 8, dither : bool = false)

  • frame - Godot::Image object to write to file
  • background_color - GIF don't support transparency - background color is applied as the background layer
  • frame_delay - delay of this frame
  • bit_depth - bit depth of this frame
  • dither - apply dithering algorithm to frame
  1. Finish gif exporting:

GifExporter.end_export()

Compilation on Linux:

  1. Init and compile godot_cpp submodule
  • Linux target uses GCC by default
  • scons platform=linux generate_bindings=yes target=release bits=32
  • scons platform=linux generate_bindings=yes target=release bits=64
  • Windows target requires mingw32 (on Arch in AUR as mingw-w64-gcc package)
  • scons platform=windows generate_bindings=yes target=release bits=32
  • scons platform=windows generate_bindings=yes target=release bits=64
  1. Compile gifexporter
  • I assume all prerequisities from the previous step are installed
  • scons p=x11 bits=32
  • scons p=x11 bits=64
  • scons p=windows bits=32
  • scons p=windows bits=64
    • Windows libraries in bin/win have to have their suffix changed to .dll
  1. Strip all resulting binaries of symbols with strip tool to greatly reduce size (godot-cpp seems to include a lot of symbols even in the release build)

Changes to gifanimcplusplus

About

GDNative plugin adding a GifExporter node that enables GIF file export to Godot Engine 3.2

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published