Delicious Bookmark this on Delicious Share on Facebook SlashdotSlashdot It! Digg! Digg



PHP : Function Reference : Image Functions : imagegif

imagegif

Output image to browser or file (PHP 4, PHP 5)
bool imagegif ( resource image [, string filename] )

imagegif() creates the GIF file in filename from the image image. The image argument is the return from the imagecreate() or imagecreatefrom* function.

The image format will be GIF87a unless the image has been made transparent with imagecolortransparent(), in which case the image format will be GIF89a.

Parameters

image

An image resource, returned by one of the image creation functions, such as imagecreatetruecolor().

filename

The path to save the file to. If not set or NULL, the raw image stream will be outputted directly.

Return Values

Returns TRUE on success or FALSE on failure.

Notes

Note:

Since all GIF support was removed from the GD library in version 1.6, this function is not available if you are using that version of the GD library. Support is expected to return in a version subsequent to the rerelease of GIF support in the GD library in mid 2004. For more information, see the » GD Project site.

The following code snippet allows you to write more portable PHP applications by auto-detecting the type of GD support which is available. Replace the sequence header ("Content-type: image/gif"); imagegif ($im); by the more flexible sequence:

<?php
if (function_exists("imagegif")) {
   
header("Content-type: image/gif");
   
imagegif($im);
} elseif (
function_exists("imagejpeg")) {
   
header("Content-type: image/jpeg");
   
imagejpeg($im, "", 0.5);
} elseif (
function_exists("imagepng")) {
   
header("Content-type: image/png");
   
imagepng($im);
} elseif (
function_exists("imagewbmp")) {
   
header("Content-type: image/vnd.wap.wbmp");
   
imagewbmp($im);
} else {
   die(
"No image support in this PHP server");
}
?>
Note:

As of version 3.0.18 and 4.0.2 you can use the function imagetypes() in place of function_exists() for checking the presence of the various supported image formats:

<?php
if (imagetypes() & IMG_GIF) {
   
header ("Content-type: image/gif");
   
imagegif ($im);
} elseif (
imagetypes() & IMG_JPG) {
   
/* ... etc. */
}
?>

Related Examples ( Source code ) » imagegif













Code Examples / Notes » imagegif

lauri harpf

Using <IMG SRC="image.php"> to dynamically generate images is a bit problematic regarding cache. Unless caching is activated, IE seems to get confused about the type of the image when attempting to save it. A .GIF created in the above way causes the browser to suggest saving the image with .BMP, not .GIF.
A solution is to activate cache with session_cache_limiter('public'); in "image.php", after which IE will correctly save as .GIF. If you do not want the cache to block any changes in the dynamic image, make sure that the SRC keeps changing with every reload. Something like "image.php/" . mt_rand(1,100000) . ".gif" seems to work well.
Might be trivial to some, but I spent a couple of hours figuring out why IE always wants to save my dynamic .GIF's as .BMP's.


rokfaith

to create an animated gif with gifsicle, but without storing temporary images on disk:
<?
$cmd = 'gifsicle --loop -O1 --multifile --delay 25 - > '.$outfile;
$desc = array(0 => array("pipe", "r"),1 => array("pipe", "w"),2 => array("pipe", "w"));
$proc = proc_open($cmd, $desc, $pipes);
if (!is_resource($proc)) {
 die('Unable to start gifsicle');
}
for ($frame=0; $frame<$total_frames; $frame++) {
 $image = RenderFrame($frame);
 ob_start();
 imagegif($image);
 fwrite($pipes[0], ob_get_contents());
 ob_end_clean();
 imagedestroy($image);
}
fclose($pipes[0]);
fclose($pipes[1]);
fclose($pipes[2]);
proc_close($proc);
?>
just define $outfile and RenderFrame(), and that's it.


david

This is how you load and display an image file:
<?
Header("Content-Type: image/gif");
$fn=fopen("./imagefile.gif","r");
fpassthru($fn);
?>
Note that there are no new-lines in the content type header.


tom et lenderlab dit com

The rgb2gif utility included in giflib can be used for fast and easy gif output with any version of GD
http://ietpd1.sowi.uni-mainz.de/cgi-bin/man2html?rgb2gif
use either the rgboutput or the rgboutput_truecolor functions, depending on your GD version/style of image you're working with:
<?
$x=40;
$y=40;
//make a simple image with some text
$im = imagecreate($x, $y);
$bg = imagecolorallocate($im, 0,0,0);
     imagefill($im, 0,0, $bg);
$red=imagecolorallocate($im, 255, 0, 0);
   imagestring($im, 1, 2, 8, "testing", $red);
//output the 24 bit rgb-formatted image to file
$f = fopen("image.rgb", "w");
fwrite($f, rgboutput($im));
imagedestroy($im);
//load that file into rgb2gif and capture the output
$status = `rgb2gif -1 -s $x $y image.rgb`;
$f = fopen("test.gif", "w");
fwrite($f, $status);
function rgboutput($im) {
   $x = imagesx($im);
   $y = imagesy($im);
   $output="";
   for($i=0;$i<$y;$i++) {
       for($j=0;$j<$x;$j++) {
           $c=ImageColorAt($im, $j, $i);
           $c = imagecolorsforindex($im, $c);
           $c = array_map("chr", $c);
           $output.=$c['red'].$c['green'].$c['blue'];
       }
   }
   return $output;
}
function rgboutput_truecolor($im) {
   $x = imagesx($im);
   $y = imagesy($im);
   $output="";
   for($i=0;$i<$y;$i++) {
       for($j=0;$j<$x;$j++) {
           $rgb=ImageColorAt($im, $j, $i);
           $r = chr(($rgb >> 16) & 0xFF);
           $g = chr(($rgb >> 8) & 0xFF);
           $b = chr($rgb & 0xFF);
           $output.=$r.$g.$b;
       }
   }
   return $output;
}
?><img src="test.gif">


leigh purdie

Simple animated-gif hack (requires ImageMagick):
<html><body>
<?php
       $icount=0;
       for($count=0;$count<40;$count++) {
               $im=imagecreate(200,200);
               imagecolorallocate($im,0,0,255);
               $white=imagecolorallocate($im,255,255,255);
               imagerectangle($im,$count,$count,200-$count,200-$count,$white);
               $icount++;
               $tcount=sprintf("%04d",$icount);
               imagegif($im,"/tmp/test-$tcount.gif");
               imagedestroy($im);
       }
       exec("/usr/bin/convert -delay 2 -loop 10 /tmp/test*.gif /var/www/html/Tests/Test-Anim.gif");
?>
<img src="/Tests/Test-Anim.gif">
</body>
</html>


polone

read also RFC2557: http://www.ietf.org/rfc/rfc2557.txt
For handling inline images in email.
----
I've been playing around with the "data" URL scheme as proposed by RFC 2397 which states how to perform inline, bas64 encoded images. A number of browsers support this format from some of my tests and would be an interesting way of removing overhead from multiple HTTP connections. Basically, the IMG tag would be:
<IMG SRC="/-/ AAAC8IyPqcvt3wCcDkiLc7C0qwyGHhSWpjQu5yqmCYsapyuvUUlvONmOZtfzgFz ByTB10QgxOR0TqBQejhRNzOfkVJ+5YiUqrXF5Y5lKh/DeuNcP5yLWGsEbtLiOSp a/TPg7JpJHxyendzWTBfX0cxOnKPjgBzi4diinWGdkF8kjdfnycQZXZeYGejmJl ZeGl9i2icVqaNVailT6F5iJ90m6mvuTS4OK05M0vDk0Q4XUtwvKOzrcd3iq9uis F81M1OIcR7lEewwcLp7tuNNkM3uNna3F2JQFo97Vriy/Xl4/f1cf5VWzXyym7PH hhx4dbgYKAAA7" ALT="Larry">
Something like that. Note also that I start the URI with "/-/" before the rest of the data scheme spec. If you don't start it with this, it won't work in a lot of the different browsers I tested (such as IE). Note this is useful for very small images only (as most browsers appear to have a limitation on the size of HTML element data of 1024). Browsers where this syntax worked that I tested are the following:
IE 6.x (windows)
Mozilla 0.97+ (linux)
Opera 5, 6 (windows)
Netscape 4.7+ (mac, windows)
IE 5 (macintosh)
This should work for other image types as well, such as PNG. JPEG files aren't really suggested (usually, these files are too large). BTW - there is no advantage to this method if the image will appear more than ONCE in the page because you will be transmitting the same data multiple times as opposed to just once (most browsers realize that already downloaded data that has multiple references only requires one HTTP call).
Consider using this method if you want to make a single PHP program that outputs both text and an image AND you want to make only on HTTP call. Cheers.


rob

Note that contrary to the documentation, export will fail if the 2nd argument is set explicitally to null.
imagegif($hd); // outputs to buffer
imagegif($hd,null); // fails


till

ImageGIF() outputs an image created by PHP. Since php cannot create animated or multiple images in a single file
it cannot handle animated GIFs.
To read GIF images use the function ImageCreateFromGIF.
--marcus
imagegif doesn't seem to work on "animated" gifs. .-(


danny

If you want to have a page with dynamic text and a dynamic image based on one form, use two php's.  One is the page which has a call to the other in an img tag:
<img src="myImage.php?name=value...


jemore

If you open a truecolor image (with imageCreateFromPng for example), and you save it directly with imagegif, you can have a 500 internal server error. You must use imageTrueColorToPalette to reduce to 256 colors before saving the image in GIF format.

rokfaith

I've recieved e-mails on this, so i will elaborate (original post ~2 posts down):
the RenderFrame($frame) function should be a function that returns an image resource and does something sensibe with the integer (frame number) that it gets passed.
function RenderFrame($frame) {
 $im = imagecreatetruecolor(100,100); //or just imagecreate for smaller images
 imageantialias($im, true); //works only on true color images, slower
 //draw something on image (imageline, imagerect, imageftt...)
 return $im;
}
this way the image is drawn and destroyed every iteration of the loop, so you can animate moving things, eg. text. if you keep the image between function calls, you get the effect of progressively drawing the image:
change
  $im = imagecreatetruecolor(100,100);
into
 static $im = imagecreatetruecolor(100,100);


cascade

I would rather use gifsicle ( http://www.lcdf.org/gifsicle/ ) instead of convert. It runs much faster with big animations. I got large animations with over 500 frames rendered where convert was killed by my system because of memory consumption. And it contains pretty well optimization.
A sample gifsicle usage (not much optimized):
<?
// Sample gifsicle usage to create a scrolling text
$gifsicle = "/usr/local/bin/gifsicle"; # http://www.lcdf.org/gifsicle/
$time = time();
for ($rend_frame = 0; $rend_frame <= 26; $rend_frame++) {
   $im = @imagecreatetruecolor(300, 20);
   $background = imagecolorallocate($im, 0, 0, 100);
   $red = imagecolorallocate($im, 255, 0, 0);
   $filename = "/tmp/giftest_".$time."_".str_pad($rend_frame, 10, "0", STR_PAD_LEFT).".gif";
   $framefiles[] = $filename;
   imagestring($im, 3, ($rend_frame * 15)-80, 3, "Animation rox", $red);
   imagegif($im,$filename);
   imagedestroy($im);
};
$outfile = "/tmp/giftest_".$time.".gif";
$cmd = "$gifsicle --loop -O1 --delay 25 /tmp/giftest_".$time."*> $outfile";
exec($cmd, $out, $err);
foreach ($framefiles as $framefile) {
   if (file_exists($framefile)) unlink($framefile);
};
header('Content-type: image/gif');
header('Content-Transfer-Encoding: binary');
header('Content-Disposition: inline; filename=test.gif');
header('Content-Length: '.@filesize($outfile));
readfile($outfile);
unlink($outfile);
?>
Or get patches from http://hyvatti.iki.fi/~jaakko/sw/ to be able to do it all inside php...


joconoco

i havent worked with it, yet. but for the discussion about animated gifs, this might help, too:
http://ffmpeg-php.sourceforge.net/apidoc.php


2ge

Hello,
there is many guides how to make animated gif (with or without temp files), but I found this really nice solution, it uses no patched GD, no external utils, just pure PHP. Look into http://www.phpclasses.org/browse/package/3163.html
Hope this helps.


fieldy

For using the new animated gif functions of gd you can build in some functions in php. I took the patch from http://hyvatti.iki.fi/~jaakko/sw/. But it's a patch on php 5.0.2. I made it on php 5.1.2.
On http://www.linuxforhomies.be/view_artikel.jsp?id=10 you can see how to do it. Sorry that it's in dutch, but I think it's understandable.
It adds following functions:
int imagegifanimbegin(int im [, string filename [, int GlobalColormap [, int Loops]]]);
int imagegifanimadd(int im [, string filename [, int LocalColormap [, LeftOfs [, int TopOfs [, int Delay [, int Disposal [, int previm]]]]]]]);
int imagegifanimend([string filename]);


kremlin

Animated GIFs as well as transparent GIFs qualify as GIF89a's and you should use ImageColorTransparent().

Change Language


Follow Navioo On Twitter
gd_info
getimagesize
image_type_to_extension
image_type_to_mime_type
image2wbmp
imagealphablending
imageantialias
imagearc
imagechar
imagecharup
imagecolorallocate
imagecolorallocatealpha
imagecolorat
imagecolorclosest
imagecolorclosestalpha
imagecolorclosesthwb
imagecolordeallocate
imagecolorexact
imagecolorexactalpha
imagecolormatch
imagecolorresolve
imagecolorresolvealpha
imagecolorset
imagecolorsforindex
imagecolorstotal
imagecolortransparent
imageconvolution
imagecopy
imagecopymerge
imagecopymergegray
imagecopyresampled
imagecopyresized
imagecreate
imagecreatefromgd2
imagecreatefromgd2part
imagecreatefromgd
imagecreatefromgif
imagecreatefromjpeg
imagecreatefrompng
imagecreatefromstring
imagecreatefromwbmp
imagecreatefromxbm
imagecreatefromxpm
imagecreatetruecolor
imagedashedline
imagedestroy
imageellipse
imagefill
imagefilledarc
imagefilledellipse
imagefilledpolygon
imagefilledrectangle
imagefilltoborder
imagefilter
imagefontheight
imagefontwidth
imageftbbox
imagefttext
imagegammacorrect
imagegd2
imagegd
imagegif
imagegrabscreen
imagegrabwindow
imageinterlace
imageistruecolor
imagejpeg
imagelayereffect
imageline
imageloadfont
imagepalettecopy
imagepng
imagepolygon
imagepsbbox
imagepsencodefont
imagepsextendfont
imagepsfreefont
imagepsloadfont
imagepsslantfont
imagepstext
imagerectangle
imagerotate
imagesavealpha
imagesetbrush
imagesetpixel
imagesetstyle
imagesetthickness
imagesettile
imagestring
imagestringup
imagesx
imagesy
imagetruecolortopalette
imagettfbbox
imagettftext
imagetypes
imagewbmp
imagexbm
iptcembed
iptcparse
jpeg2wbmp
png2wbmp
eXTReMe Tracker