aboutsummaryrefslogtreecommitdiff
path: root/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder
diff options
context:
space:
mode:
Diffstat (limited to 'libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder')
-rw-r--r--libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/Example.php50
-rw-r--r--libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/GIFEncoder.class.php267
-rw-r--r--libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/GIFEncoder.class.phpvideotoolkit.php270
-rw-r--r--libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/example.gifbin0 -> 41694 bytes
-rw-r--r--libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images01.gifbin0 -> 3370 bytes
-rw-r--r--libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images02.gifbin0 -> 3319 bytes
-rw-r--r--libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images03.gifbin0 -> 3051 bytes
-rw-r--r--libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images04.gifbin0 -> 2890 bytes
-rw-r--r--libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images05.gifbin0 -> 2929 bytes
-rw-r--r--libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images06.gifbin0 -> 3142 bytes
-rw-r--r--libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images07.gifbin0 -> 3352 bytes
-rw-r--r--libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images08.gifbin0 -> 3422 bytes
-rw-r--r--libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images09.gifbin0 -> 3183 bytes
-rw-r--r--libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images10.gifbin0 -> 3050 bytes
-rw-r--r--libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images11.gifbin0 -> 2971 bytes
-rw-r--r--libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images12.gifbin0 -> 3073 bytes
-rw-r--r--libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images13.gifbin0 -> 3205 bytes
-rw-r--r--libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/screenshot.gifbin0 -> 41693 bytes
18 files changed, 587 insertions, 0 deletions
diff --git a/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/Example.php b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/Example.php
new file mode 100644
index 0000000..1223002
--- /dev/null
+++ b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/Example.php
@@ -0,0 +1,50 @@
+<?php
+include "GIFEncoder.class.php";
+/*
+ Build a frames array from sources...
+*/
+if ( $dh = opendir ( "frames/" ) ) {
+ while ( false !== ( $dat = readdir ( $dh ) ) ) {
+ if ( $dat != "." && $dat != ".." ) {
+ $frames [ ] = "frames/$dat";
+ $framed [ ] = 5;
+ }
+ }
+ closedir ( $dh );
+}
+/*
+ GIFEncoder constructor:
+ =======================
+
+ image_stream = new GIFEncoder (
+ URL or Binary data 'Sources'
+ int 'Delay times'
+ int 'Animation loops'
+ int 'Disposal'
+ int 'Transparent red, green, blue colors'
+ int 'Source type'
+ );
+*/
+$gif = new GIFEncoder (
+ $frames,
+ $framed,
+ 0,
+ 2,
+ 0, 0, 0,
+ 0,
+ "url"
+ );
+/*
+ Possibles outputs:
+ ==================
+
+ Output as GIF for browsers :
+ - Header ( 'Content-type:image/gif' );
+ Output as GIF for browsers with filename:
+ - Header ( 'Content-disposition:Attachment;filename=myanimation.gif');
+ Output as file to store into a specified file:
+ - FWrite ( FOpen ( "myanimation.gif", "wb" ), $gif->GetAnimation ( ) );
+*/
+Header ( 'Content-type:image/gif' );
+echo $gif->GetAnimation ( );
+?>
diff --git a/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/GIFEncoder.class.php b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/GIFEncoder.class.php
new file mode 100644
index 0000000..0c38b02
--- /dev/null
+++ b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/GIFEncoder.class.php
@@ -0,0 +1,267 @@
+<?php
+/*
+:::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
+::
+:: GIFEncoder Version 3.0 by László Zsidi, http://gifs.hu
+::
+:: This class is a rewritten 'GifMerge.class.php' version.
+::
+:: Modification:
+:: - Simplified and easy code,
+:: - Ultra fast encoding,
+:: - Built-in errors,
+:: - Stable working
+::
+::
+:: Updated at 2007. 02. 13. '00.05.AM'
+::
+::
+::
+:: Try on-line GIFBuilder Form demo based on GIFEncoder.
+::
+:: http://gifs.hu/phpclasses/demos/GifBuilder/
+::
+:::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
+*/
+
+Class GIFEncoder {
+ var $GIF = "GIF89a"; /* GIF header 6 bytes */
+ var $VER = "GIFEncoder V3.00"; /* Encoder version */
+
+ var $BUF = Array ( );
+ var $OFS = Array ( );
+ var $SIG = 0;
+ var $LOP = 0;
+ var $DIS = 2;
+ var $COL = -1;
+ var $IMG = -1;
+
+ var $ERR = Array (
+ ERR00=>"Does not supported function for only one image!",
+ ERR01=>"Source is not a GIF image!",
+ ERR02=>"Unintelligible flag ",
+ ERR03=>"Does not make animation from animated GIF source",
+ );
+
+ /*
+ :::::::::::::::::::::::::::::::::::::::::::::::::::
+ ::
+ :: GIFEncoder...
+ ::
+ */
+ function GIFEncoder (
+ $GIF_src, $GIF_dly, $GIF_lop, $GIF_dis,
+ $GIF_red, $GIF_grn, $GIF_blu, $GIF_ofs,
+ $GIF_mod
+ ) {
+ if ( ! is_array ( $GIF_src ) && ! is_array ( $GIF_dly ) ) {
+ printf ( "%s: %s", $this->VER, $this->ERR [ 'ERR00' ] );
+ exit ( 0 );
+ }
+ if ( is_array ( $GIF_ofs ) && count ( $GIF_ofs ) > 1 ) {
+ $this->SIG = 1;
+ $this->OFS = $GIF_ofs;
+ }
+ $this->LOP = ( $GIF_lop > -1 ) ? $GIF_lop : 0;
+ $this->DIS = ( $GIF_dis > -1 ) ? ( ( $GIF_dis < 3 ) ? $GIF_dis : 3 ) : 2;
+ $this->COL = ( $GIF_red > -1 && $GIF_grn > -1 && $GIF_blu > -1 ) ?
+ ( $GIF_red | ( $GIF_grn << 8 ) | ( $GIF_blu << 16 ) ) : -1;
+
+ for ( $i = 0; $i < count ( $GIF_src ); $i++ ) {
+ if ( strToLower ( $GIF_mod ) == "url" ) {
+ $this->BUF [ ] = fread ( fopen ( $GIF_src [ $i ], "rb" ), filesize ( $GIF_src [ $i ] ) );
+ }
+ else if ( strToLower ( $GIF_mod ) == "bin" ) {
+ $this->BUF [ ] = $GIF_src [ $i ];
+ }
+ else {
+ printf ( "%s: %s ( %s )!", $this->VER, $this->ERR [ 'ERR02' ], $GIF_mod );
+ exit ( 0 );
+ }
+ if ( substr ( $this->BUF [ $i ], 0, 6 ) != "GIF87a" && substr ( $this->BUF [ $i ], 0, 6 ) != "GIF89a" ) {
+ printf ( "%s: %d %s", $this->VER, $i, $this->ERR [ 'ERR01' ] );
+ exit ( 0 );
+ }
+ for ( $j = ( 13 + 3 * ( 2 << ( ord ( $this->BUF [ $i ] { 10 } ) & 0x07 ) ) ), $k = TRUE; $k; $j++ ) {
+ switch ( $this->BUF [ $i ] { $j } ) {
+ case "!":
+ if ( ( substr ( $this->BUF [ $i ], ( $j + 3 ), 8 ) ) == "NETSCAPE" ) {
+ printf ( "%s: %s ( %s source )!", $this->VER, $this->ERR [ 'ERR03' ], ( $i + 1 ) );
+ exit ( 0 );
+ }
+ break;
+ case ";":
+ $k = FALSE;
+ break;
+ }
+ }
+ }
+ GIFEncoder::GIFAddHeader ( );
+ for ( $i = 0; $i < count ( $this->BUF ); $i++ ) {
+ GIFEncoder::GIFAddFrames ( $i, $GIF_dly [ $i ] );
+ }
+ GIFEncoder::GIFAddFooter ( );
+ }
+ /*
+ :::::::::::::::::::::::::::::::::::::::::::::::::::
+ ::
+ :: GIFAddHeader...
+ ::
+ */
+ function GIFAddHeader ( ) {
+ $cmap = 0;
+
+ if ( ord ( $this->BUF [ 0 ] { 10 } ) & 0x80 ) {
+ $cmap = 3 * ( 2 << ( ord ( $this->BUF [ 0 ] { 10 } ) & 0x07 ) );
+
+ $this->GIF .= substr ( $this->BUF [ 0 ], 6, 7 );
+ $this->GIF .= substr ( $this->BUF [ 0 ], 13, $cmap );
+ $this->GIF .= "!\377\13NETSCAPE2.0\3\1" . GIFEncoder::GIFWord ( $this->LOP ) . "\0";
+ }
+ }
+ /*
+ :::::::::::::::::::::::::::::::::::::::::::::::::::
+ ::
+ :: GIFAddFrames...
+ ::
+ */
+ function GIFAddFrames ( $i, $d ) {
+
+ $Locals_str = 13 + 3 * ( 2 << ( ord ( $this->BUF [ $i ] { 10 } ) & 0x07 ) );
+
+ $Locals_end = strlen ( $this->BUF [ $i ] ) - $Locals_str - 1;
+ $Locals_tmp = substr ( $this->BUF [ $i ], $Locals_str, $Locals_end );
+
+ $Global_len = 2 << ( ord ( $this->BUF [ 0 ] { 10 } ) & 0x07 );
+ $Locals_len = 2 << ( ord ( $this->BUF [ $i ] { 10 } ) & 0x07 );
+
+ $Global_rgb = substr ( $this->BUF [ 0 ], 13,
+ 3 * ( 2 << ( ord ( $this->BUF [ 0 ] { 10 } ) & 0x07 ) ) );
+ $Locals_rgb = substr ( $this->BUF [ $i ], 13,
+ 3 * ( 2 << ( ord ( $this->BUF [ $i ] { 10 } ) & 0x07 ) ) );
+
+ $Locals_ext = "!\xF9\x04" . chr ( ( $this->DIS << 2 ) + 0 ) .
+ chr ( ( $d >> 0 ) & 0xFF ) . chr ( ( $d >> 8 ) & 0xFF ) . "\x0\x0";
+
+ if ( $this->COL > -1 && ord ( $this->BUF [ $i ] { 10 } ) & 0x80 ) {
+ for ( $j = 0; $j < ( 2 << ( ord ( $this->BUF [ $i ] { 10 } ) & 0x07 ) ); $j++ ) {
+ if (
+ ord ( $Locals_rgb { 3 * $j + 0 } ) == ( ( $this->COL >> 16 ) & 0xFF ) &&
+ ord ( $Locals_rgb { 3 * $j + 1 } ) == ( ( $this->COL >> 8 ) & 0xFF ) &&
+ ord ( $Locals_rgb { 3 * $j + 2 } ) == ( ( $this->COL >> 0 ) & 0xFF )
+ ) {
+ $Locals_ext = "!\xF9\x04" . chr ( ( $this->DIS << 2 ) + 1 ) .
+ chr ( ( $d >> 0 ) & 0xFF ) . chr ( ( $d >> 8 ) & 0xFF ) . chr ( $j ) . "\x0";
+ break;
+ }
+ }
+ }
+ switch ( $Locals_tmp { 0 } ) {
+ case "!":
+ $Locals_img = substr ( $Locals_tmp, 8, 10 );
+ $Locals_tmp = substr ( $Locals_tmp, 18, strlen ( $Locals_tmp ) - 18 );
+ break;
+ case ",":
+ $Locals_img = substr ( $Locals_tmp, 0, 10 );
+ $Locals_tmp = substr ( $Locals_tmp, 10, strlen ( $Locals_tmp ) - 10 );
+ break;
+ }
+ if ( ord ( $this->BUF [ $i ] { 10 } ) & 0x80 && $this->IMG > -1 ) {
+ if ( $Global_len == $Locals_len ) {
+ if ( GIFEncoder::GIFBlockCompare ( $Global_rgb, $Locals_rgb, $Global_len ) ) {
+ $this->GIF .= ( $Locals_ext . $Locals_img . $Locals_tmp );
+ }
+ else {
+ /*
+ *
+ * XY Padding...
+ *
+ */
+ if ( $this->SIG == 1 ) {
+ $Locals_img { 1 } = chr ( $this->OFS [ $i ] [ 0 ] & 0xFF );
+ $Locals_img { 2 } = chr ( ( $$this->OFS [ $i ] [ 0 ] & 0xFF00 ) >> 8 );
+ $Locals_img { 3 } = chr ( $this->OFS [ $i ] [ 1 ] & 0xFF );
+ $Locals_img { 4 } = chr ( ( $this->OFS [ $i ] [ 1 ] & 0xFF00 ) >> 8 );
+ }
+ $byte = ord ( $Locals_img { 9 } );
+ $byte |= 0x80;
+ $byte &= 0xF8;
+ $byte |= ( ord ( $this->BUF [ 0 ] { 10 } ) & 0x07 );
+ $Locals_img { 9 } = chr ( $byte );
+ $this->GIF .= ( $Locals_ext . $Locals_img . $Locals_rgb . $Locals_tmp );
+ }
+ }
+ else {
+ /*
+ *
+ * XY Padding...
+ *
+ */
+ if ( $this->SIG == 1 ) {
+ $Locals_img { 1 } = chr ( $this->OFS [ $i ] [ 0 ] & 0xFF );
+ $Locals_img { 2 } = chr ( ( $$this->OFS [ $i ] [ 0 ] & 0xFF00 ) >> 8 );
+ $Locals_img { 3 } = chr ( $this->OFS [ $i ] [ 1 ] & 0xFF );
+ $Locals_img { 4 } = chr ( ( $this->OFS [ $i ] [ 1 ] & 0xFF00 ) >> 8 );
+ }
+ $byte = ord ( $Locals_img { 9 } );
+ $byte |= 0x80;
+ $byte &= 0xF8;
+ $byte |= ( ord ( $this->BUF [ $i ] { 10 } ) & 0x07 );
+ $Locals_img { 9 } = chr ( $byte );
+ $this->GIF .= ( $Locals_ext . $Locals_img . $Locals_rgb . $Locals_tmp );
+ }
+ }
+ else {
+ $this->GIF .= ( $Locals_ext . $Locals_img . $Locals_tmp );
+ }
+ $this->IMG = 1;
+ }
+ /*
+ :::::::::::::::::::::::::::::::::::::::::::::::::::
+ ::
+ :: GIFAddFooter...
+ ::
+ */
+ function GIFAddFooter ( ) {
+ $this->GIF .= ";";
+ }
+ /*
+ :::::::::::::::::::::::::::::::::::::::::::::::::::
+ ::
+ :: GIFBlockCompare...
+ ::
+ */
+ function GIFBlockCompare ( $GlobalBlock, $LocalBlock, $Len ) {
+
+ for ( $i = 0; $i < $Len; $i++ ) {
+ if (
+ $GlobalBlock { 3 * $i + 0 } != $LocalBlock { 3 * $i + 0 } ||
+ $GlobalBlock { 3 * $i + 1 } != $LocalBlock { 3 * $i + 1 } ||
+ $GlobalBlock { 3 * $i + 2 } != $LocalBlock { 3 * $i + 2 }
+ ) {
+ return ( 0 );
+ }
+ }
+
+ return ( 1 );
+ }
+ /*
+ :::::::::::::::::::::::::::::::::::::::::::::::::::
+ ::
+ :: GIFWord...
+ ::
+ */
+ function GIFWord ( $int ) {
+
+ return ( chr ( $int & 0xFF ) . chr ( ( $int >> 8 ) & 0xFF ) );
+ }
+ /*
+ :::::::::::::::::::::::::::::::::::::::::::::::::::
+ ::
+ :: GetAnimation...
+ ::
+ */
+ function GetAnimation ( ) {
+ return ( $this->GIF );
+ }
+}
diff --git a/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/GIFEncoder.class.phpvideotoolkit.php b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/GIFEncoder.class.phpvideotoolkit.php
new file mode 100644
index 0000000..9dbfda7
--- /dev/null
+++ b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/GIFEncoder.class.phpvideotoolkit.php
@@ -0,0 +1,270 @@
+<?php
+/*
+:::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
+::
+:: GIFEncoder Version 3.0 by László Zsidi, http://gifs.hu
+::
+:: This class is a rewritten 'GifMerge.class.php' version.
+::
+:: Modification:
+:: - Simplified and easy code,
+:: - Ultra fast encoding,
+:: - Built-in errors,
+:: - Stable working
+::
+::
+:: Updated at 2007. 02. 13. '00.05.AM'
+::
+::
+::
+:: Try on-line GIFBuilder Form demo based on GIFEncoder.
+::
+:: http://gifs.hu/phpclasses/demos/GifBuilder/
+::
+:::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
+*/
+
+Class GIFEncoder {
+ var $GIF = "GIF89a"; /* GIF header 6 bytes */
+ var $VER = "GIFEncoder V3.00"; /* Encoder version */
+
+ var $BUF = Array ( );
+ var $OFS = Array ( );
+ var $SIG = 0;
+ var $LOP = 0;
+ var $DIS = 2;
+ var $COL = -1;
+ var $IMG = -1;
+
+ var $ERR = Array (
+ 'ERR00'=>"Does not supported function for only one image!",
+ 'ERR01'=>"Source is not a GIF image!",
+ 'ERR02'=>"Unintelligible flag ",
+ 'ERR03'=>"Does not make animation from animated GIF source",
+ );
+
+ /*
+ :::::::::::::::::::::::::::::::::::::::::::::::::::
+ ::
+ :: GIFEncoder...
+ ::
+ */
+ function GIFEncoder (
+ $GIF_src, $GIF_dly, $GIF_lop, $GIF_dis,
+ $GIF_red, $GIF_grn, $GIF_blu, $GIF_ofs,
+ $GIF_mod
+ ) {
+ if ( ! is_array ( $GIF_src ) && ! is_array ( $GIF_dly ) ) {
+ printf ( "%s: %s", $this->VER, $this->ERR [ 'ERR00' ] );
+ exit ( 0 );
+ }
+ if ( is_array ( $GIF_ofs ) && count ( $GIF_ofs ) > 1 ) {
+ $this->SIG = 1;
+ $this->OFS = $GIF_ofs;
+ }
+ $this->LOP = $GIF_lop === false ? false : (( $GIF_lop > -1 ) ? $GIF_lop : 0);
+ $this->DIS = ( $GIF_dis > -1 ) ? ( ( $GIF_dis < 3 ) ? $GIF_dis : 3 ) : 2;
+ $this->COL = ( $GIF_red > -1 && $GIF_grn > -1 && $GIF_blu > -1 ) ?
+ ( $GIF_red | ( $GIF_grn << 8 ) | ( $GIF_blu << 16 ) ) : -1;
+
+ for ( $i = 0; $i < count ( $GIF_src ); $i++ ) {
+ if ( strToLower ( $GIF_mod ) == "url" ) {
+ $this->BUF [ ] = fread ( fopen ( $GIF_src [ $i ], "rb" ), filesize ( $GIF_src [ $i ] ) );
+ }
+ else if ( strToLower ( $GIF_mod ) == "bin" ) {
+ $this->BUF [ ] = $GIF_src [ $i ];
+ }
+ else {
+ printf ( "%s: %s ( %s )!", $this->VER, $this->ERR [ 'ERR02' ], $GIF_mod );
+ exit ( 0 );
+ }
+ if ( substr ( $this->BUF [ $i ], 0, 6 ) != "GIF87a" && substr ( $this->BUF [ $i ], 0, 6 ) != "GIF89a" ) {
+ printf ( "%s: %d %s", $this->VER, $i, $this->ERR [ 'ERR01' ] );
+ exit ( 0 );
+ }
+ for ( $j = ( 13 + 3 * ( 2 << ( ord ( $this->BUF [ $i ] { 10 } ) & 0x07 ) ) ), $k = TRUE; $k; $j++ ) {
+ switch ( $this->BUF [ $i ] { $j } ) {
+ case "!":
+ if ( ( substr ( $this->BUF [ $i ], ( $j + 3 ), 8 ) ) == "NETSCAPE" ) {
+ printf ( "%s: %s ( %s source )!", $this->VER, $this->ERR [ 'ERR03' ], ( $i + 1 ) );
+ exit ( 0 );
+ }
+ break;
+ case ";":
+ $k = FALSE;
+ break;
+ }
+ }
+ }
+ GIFEncoder::GIFAddHeader ( );
+ for ( $i = 0; $i < count ( $this->BUF ); $i++ ) {
+ GIFEncoder::GIFAddFrames ( $i, $GIF_dly [ $i ] );
+ }
+ GIFEncoder::GIFAddFooter ( );
+ }
+ /*
+ :::::::::::::::::::::::::::::::::::::::::::::::::::
+ ::
+ :: GIFAddHeader...
+ ::
+ */
+ function GIFAddHeader ( ) {
+ $cmap = 0;
+
+ if ( ord ( $this->BUF [ 0 ] { 10 } ) & 0x80 ) {
+ $cmap = 3 * ( 2 << ( ord ( $this->BUF [ 0 ] { 10 } ) & 0x07 ) );
+
+ $this->GIF .= substr ( $this->BUF [ 0 ], 6, 7 );
+ $this->GIF .= substr ( $this->BUF [ 0 ], 13, $cmap );
+ if($this->LOP !== false)
+ {
+ $this->GIF .= "!\377\13NETSCAPE2.0\3\1" . GIFEncoder::GIFWord ( $this->LOP ) . "\0";
+ }
+ }
+ }
+ /*
+ :::::::::::::::::::::::::::::::::::::::::::::::::::
+ ::
+ :: GIFAddFrames...
+ ::
+ */
+ function GIFAddFrames ( $i, $d ) {
+
+ $Locals_str = 13 + 3 * ( 2 << ( ord ( $this->BUF [ $i ] { 10 } ) & 0x07 ) );
+
+ $Locals_end = strlen ( $this->BUF [ $i ] ) - $Locals_str - 1;
+ $Locals_tmp = substr ( $this->BUF [ $i ], $Locals_str, $Locals_end );
+
+ $Global_len = 2 << ( ord ( $this->BUF [ 0 ] { 10 } ) & 0x07 );
+ $Locals_len = 2 << ( ord ( $this->BUF [ $i ] { 10 } ) & 0x07 );
+
+ $Global_rgb = substr ( $this->BUF [ 0 ], 13,
+ 3 * ( 2 << ( ord ( $this->BUF [ 0 ] { 10 } ) & 0x07 ) ) );
+ $Locals_rgb = substr ( $this->BUF [ $i ], 13,
+ 3 * ( 2 << ( ord ( $this->BUF [ $i ] { 10 } ) & 0x07 ) ) );
+
+ $Locals_ext = "!\xF9\x04" . chr ( ( $this->DIS << 2 ) + 0 ) .
+ chr ( ( $d >> 0 ) & 0xFF ) . chr ( ( $d >> 8 ) & 0xFF ) . "\x0\x0";
+
+ if ( $this->COL > -1 && ord ( $this->BUF [ $i ] { 10 } ) & 0x80 ) {
+ for ( $j = 0; $j < ( 2 << ( ord ( $this->BUF [ $i ] { 10 } ) & 0x07 ) ); $j++ ) {
+ if (
+ ord ( $Locals_rgb { 3 * $j + 0 } ) == ( ( $this->COL >> 16 ) & 0xFF ) &&
+ ord ( $Locals_rgb { 3 * $j + 1 } ) == ( ( $this->COL >> 8 ) & 0xFF ) &&
+ ord ( $Locals_rgb { 3 * $j + 2 } ) == ( ( $this->COL >> 0 ) & 0xFF )
+ ) {
+ $Locals_ext = "!\xF9\x04" . chr ( ( $this->DIS << 2 ) + 1 ) .
+ chr ( ( $d >> 0 ) & 0xFF ) . chr ( ( $d >> 8 ) & 0xFF ) . chr ( $j ) . "\x0";
+ break;
+ }
+ }
+ }
+ switch ( $Locals_tmp { 0 } ) {
+ case "!":
+ $Locals_img = substr ( $Locals_tmp, 8, 10 );
+ $Locals_tmp = substr ( $Locals_tmp, 18, strlen ( $Locals_tmp ) - 18 );
+ break;
+ case ",":
+ $Locals_img = substr ( $Locals_tmp, 0, 10 );
+ $Locals_tmp = substr ( $Locals_tmp, 10, strlen ( $Locals_tmp ) - 10 );
+ break;
+ }
+ if ( ord ( $this->BUF [ $i ] { 10 } ) & 0x80 && $this->IMG > -1 ) {
+ if ( $Global_len == $Locals_len ) {
+ if ( GIFEncoder::GIFBlockCompare ( $Global_rgb, $Locals_rgb, $Global_len ) ) {
+ $this->GIF .= ( $Locals_ext . $Locals_img . $Locals_tmp );
+ }
+ else {
+ /*
+ *
+ * XY Padding...
+ *
+ */
+ if ( $this->SIG == 1 ) {
+ $Locals_img { 1 } = chr ( $this->OFS [ $i ] [ 0 ] & 0xFF );
+ $Locals_img { 2 } = chr ( ( $$this->OFS [ $i ] [ 0 ] & 0xFF00 ) >> 8 );
+ $Locals_img { 3 } = chr ( $this->OFS [ $i ] [ 1 ] & 0xFF );
+ $Locals_img { 4 } = chr ( ( $this->OFS [ $i ] [ 1 ] & 0xFF00 ) >> 8 );
+ }
+ $byte = ord ( $Locals_img { 9 } );
+ $byte |= 0x80;
+ $byte &= 0xF8;
+ $byte |= ( ord ( $this->BUF [ 0 ] { 10 } ) & 0x07 );
+ $Locals_img { 9 } = chr ( $byte );
+ $this->GIF .= ( $Locals_ext . $Locals_img . $Locals_rgb . $Locals_tmp );
+ }
+ }
+ else {
+ /*
+ *
+ * XY Padding...
+ *
+ */
+ if ( $this->SIG == 1 ) {
+ $Locals_img { 1 } = chr ( $this->OFS [ $i ] [ 0 ] & 0xFF );
+ $Locals_img { 2 } = chr ( ( $$this->OFS [ $i ] [ 0 ] & 0xFF00 ) >> 8 );
+ $Locals_img { 3 } = chr ( $this->OFS [ $i ] [ 1 ] & 0xFF );
+ $Locals_img { 4 } = chr ( ( $this->OFS [ $i ] [ 1 ] & 0xFF00 ) >> 8 );
+ }
+ $byte = ord ( $Locals_img { 9 } );
+ $byte |= 0x80;
+ $byte &= 0xF8;
+ $byte |= ( ord ( $this->BUF [ $i ] { 10 } ) & 0x07 );
+ $Locals_img { 9 } = chr ( $byte );
+ $this->GIF .= ( $Locals_ext . $Locals_img . $Locals_rgb . $Locals_tmp );
+ }
+ }
+ else {
+ $this->GIF .= ( $Locals_ext . $Locals_img . $Locals_tmp );
+ }
+ $this->IMG = 1;
+ }
+ /*
+ :::::::::::::::::::::::::::::::::::::::::::::::::::
+ ::
+ :: GIFAddFooter...
+ ::
+ */
+ function GIFAddFooter ( ) {
+ $this->GIF .= ";";
+ }
+ /*
+ :::::::::::::::::::::::::::::::::::::::::::::::::::
+ ::
+ :: GIFBlockCompare...
+ ::
+ */
+ function GIFBlockCompare ( $GlobalBlock, $LocalBlock, $Len ) {
+
+ for ( $i = 0; $i < $Len; $i++ ) {
+ if (
+ $GlobalBlock { 3 * $i + 0 } != $LocalBlock { 3 * $i + 0 } ||
+ $GlobalBlock { 3 * $i + 1 } != $LocalBlock { 3 * $i + 1 } ||
+ $GlobalBlock { 3 * $i + 2 } != $LocalBlock { 3 * $i + 2 }
+ ) {
+ return ( 0 );
+ }
+ }
+
+ return ( 1 );
+ }
+ /*
+ :::::::::::::::::::::::::::::::::::::::::::::::::::
+ ::
+ :: GIFWord...
+ ::
+ */
+ function GIFWord ( $int ) {
+
+ return ( chr ( $int & 0xFF ) . chr ( ( $int >> 8 ) & 0xFF ) );
+ }
+ /*
+ :::::::::::::::::::::::::::::::::::::::::::::::::::
+ ::
+ :: GetAnimation...
+ ::
+ */
+ function GetAnimation ( ) {
+ return ( $this->GIF );
+ }
+}
diff --git a/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/example.gif b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/example.gif
new file mode 100644
index 0000000..86e90d4
--- /dev/null
+++ b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/example.gif
Binary files differ
diff --git a/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images01.gif b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images01.gif
new file mode 100644
index 0000000..01e9a1c
--- /dev/null
+++ b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images01.gif
Binary files differ
diff --git a/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images02.gif b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images02.gif
new file mode 100644
index 0000000..8ee3775
--- /dev/null
+++ b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images02.gif
Binary files differ
diff --git a/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images03.gif b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images03.gif
new file mode 100644
index 0000000..cae3827
--- /dev/null
+++ b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images03.gif
Binary files differ
diff --git a/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images04.gif b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images04.gif
new file mode 100644
index 0000000..dff4629
--- /dev/null
+++ b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images04.gif
Binary files differ
diff --git a/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images05.gif b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images05.gif
new file mode 100644
index 0000000..4605688
--- /dev/null
+++ b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images05.gif
Binary files differ
diff --git a/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images06.gif b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images06.gif
new file mode 100644
index 0000000..3e51360
--- /dev/null
+++ b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images06.gif
Binary files differ
diff --git a/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images07.gif b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images07.gif
new file mode 100644
index 0000000..7673508
--- /dev/null
+++ b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images07.gif
Binary files differ
diff --git a/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images08.gif b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images08.gif
new file mode 100644
index 0000000..5f1facc
--- /dev/null
+++ b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images08.gif
Binary files differ
diff --git a/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images09.gif b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images09.gif
new file mode 100644
index 0000000..48425b2
--- /dev/null
+++ b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images09.gif
Binary files differ
diff --git a/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images10.gif b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images10.gif
new file mode 100644
index 0000000..1b8f1c1
--- /dev/null
+++ b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images10.gif
Binary files differ
diff --git a/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images11.gif b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images11.gif
new file mode 100644
index 0000000..e904217
--- /dev/null
+++ b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images11.gif
Binary files differ
diff --git a/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images12.gif b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images12.gif
new file mode 100644
index 0000000..3fc7fe0
--- /dev/null
+++ b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images12.gif
Binary files differ
diff --git a/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images13.gif b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images13.gif
new file mode 100644
index 0000000..00dfbf1
--- /dev/null
+++ b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/frames/images13.gif
Binary files differ
diff --git a/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/screenshot.gif b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/screenshot.gif
new file mode 100644
index 0000000..491c030
--- /dev/null
+++ b/libraries/phpvideotoolkit/adapters/ffmpeg-php/gifencoder/screenshot.gif
Binary files differ