Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Sybio/GifCreator
GifCreator is a PHP class that creates animated GIF from multiple images
https://github.com/Sybio/GifCreator
Last synced: about 1 month ago
JSON representation
GifCreator is a PHP class that creates animated GIF from multiple images
- Host: GitHub
- URL: https://github.com/Sybio/GifCreator
- Owner: Sybio
- Created: 2012-09-25T09:29:58.000Z (about 12 years ago)
- Default Branch: master
- Last Pushed: 2021-09-18T18:40:16.000Z (about 3 years ago)
- Last Synced: 2024-10-29T22:51:36.576Z (about 1 month ago)
- Language: PHP
- Homepage:
- Size: 117 KB
- Stars: 325
- Watchers: 25
- Forks: 150
- Open Issues: 21
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-gif - GifCreator - PHP class that creates animated GIF from multiple images. (Libraries / PHP)
- awesome-php-cn - Sybio/GifCreator - 从多幅图片中创建GIF动画的库 (目录 / 图像 Imagery)
README
# ================================
# GifCreator
# ================================GifCreator is a PHP class to create animated GIF from multiple images
### For what ?
This class helps you to create an animated GIF image: give multiple images and their duration and that's it !
### Usage
**1 - Creation:**
```php
// Create an array containing file paths, resource var (initialized with imagecreatefromXXX),
// image URLs or even binary code from image files.
// All sorted in order to appear.
$frames = array(
imagecreatefrompng("/../images/pic1.png"), // Resource var
"/../images/pic2.png", // Image file path
file_get_contents("/../images/pic3.jpg"), // Binary source code
'http://thisisafakedomain.com/images/pic4.jpg', // URL
);// Create an array containing the duration (in millisecond) of each frames (in order too)
$durations = array(40, 80, 40, 20);// Initialize and create the GIF !
$gc = new GifCreator();
$gc->create($frames, $durations, 5);
```
The 3rd parameter of create() method allows you to choose the number of loop of your animated gif before it stops.
In the previous example, I chose 5 loops. Set 0 (zero) to get an infinite loop.**2 - Get the result:**
You can now get the animated GIF binary:
```php
$gifBinary = $gc->getGif();
```Then you can show it in the navigator:
```php
header('Content-type: image/gif');
header('Content-Disposition: filename="butterfly.gif"');
echo $gifBinary;
exit;
```Or save it in a folder as a GIF:
```php
file_put_contents('/myfolder/animated_picture.gif', $gifBinary);
```### Behavior
- The transparency is based on the first given frame. It will be saved only if you give multiple frames with same transparent background.
- The dimensions of the generated GIF are based on the first frame. If you need to resize your frames to get the same dimension, you can use
this class: https://github.com/Sybio/ImageWorkshop### About
The class reuses some part of code of "GIFEncoder.class.php" by László Zsidi (thanks to him).