Animated GIF HTML Image Slide Tutorial

Animated GIF HTML Image Slide Tutorial

Animated GIF HTML Image Slide Tutorial

Further to yesterday’s Animated GIF SVG Slide Tutorial

  • SVG vector image extraction from HTML input … today we want to add in …
  • an additional + suffix will look for other HTML img element data in the user defined hTTp specified URL to point at their input HTML data source, for this

It’s early days but we do not need ImageMagick here, so we think we can get places using Ajax calling code like …

<?php echo ”

if (imgurl.toLowerCase().indexOf('http') == 0) {
if (1 == 1) {
imos.push(new XMLHttpRequest());
imos[eval(-1 + imos.length)].title=imgurl;
imos[eval(-1 + imos.length)].onreadystatechange = function() {
var sid=1, x, ttl, sfx='', lastok='';
var defdata='';
var toosmall=eval('' + ('').length);
toosmall=100;
x = this;
ttl = x.title;
if (((x.readyState == 4) && (x.status == 200 || x.status == 403 || x.status == 404))) {
console.log('rs=' + x.readyState + ' status=' + x.status + ' Ttl=' + ttl + ' and response length=' + x.response.length + ' and imgurl=' + imgurl);
for (var iik=0; iik<tothers.length; iik++) {
if (tothers[iik].indexOf(ttl + '#') == 0) {
if (x.response.trim().indexOf('data:') != 0) {
tothers[iik]='';
} else {
sfx='#' + tothers[iik].split('#')[1]; tothers[iik]=x.response + sfx;
}
}
}
lastok=defdata;
if (document.getElementById(('slideshow' + sid).replace(/^slideshow1$/g,'slideshow')).value.indexOf('data:') == 0 && eval('' + document.getElementById(('slideshow' + sid).replace(/^slideshow1$/g,'slideshow')).value.length) > toosmall) {
lastok=document.getElementById(('slideshow' + sid).replace(/^slideshow1$/g,'slideshow')).value;
}
while (document.getElementById(('slideshow' + sid).replace(/^slideshow1$/g,'slideshow'))) {
if (document.getElementById(('slideshow' + sid).replace(/^slideshow1$/g,'slideshow')).value.indexOf(ttl) == 0) {
if (eval('' + x.response.trim().length) <= toosmall) {
console.log('1 rs=' + x.readyState + ' status=' + x.status + ' Ttl=' + ttl + ' and response length=' + x.response.length);
document.getElementById(('slideshow' + sid).replace(/^slideshow1$/g,'slideshow')).value=defdata;
} else if (x.response.trim().indexOf('data:') != 0 && lastok == '') {
//alert('Why ' + sid);
console.log('2 rs=' + x.readyState + ' status=' + x.status + ' Ttl=' + ttl + ' and response length=' + x.response.length);
document.getElementById(('slideshow' + sid).replace(/^slideshow1$/g,'slideshow')).value=defdata;
} else if (x.response.trim().indexOf('data:') != 0 && lastok != '') {
console.log('3 rs=' + x.readyState + ' status=' + x.status + ' Ttl=' + ttl + ' and response length=' + x.response.length);
document.getElementById(('slideshow' + sid).replace(/^slideshow1$/g,'slideshow')).value=lastok;
} else {
console.log('4 rs=' + x.readyState + ' status=' + x.status + ' Ttl=' + ttl + ' and response length=' + x.response.length);
document.getElementById(('slideshow' + sid).replace(/^slideshow1$/g,'slideshow')).value=x.response;
lastok=x.response;
}
} else if (document.getElementById(('slideshow' + sid).replace(/^slideshow1$/g,'slideshow')).value.indexOf('data:') == 0 && eval('' + document.getElementById(('slideshow' + sid).replace(/^slideshow1$/g,'slideshow')).value.length) > toosmall) {
console.log('0 rs=' + x.readyState + ' status=' + x.status + ' Ttl=' + ttl + ' and response length=' + x.response.length);
lastok=document.getElementById(('slideshow' + sid).replace(/^slideshow1$/g,'slideshow')).value;
}
sid++;
}
}
};
imos[eval(-1 + imos.length)].open('get', '/PHP/fgc/index.php?askimg=' + imgurl, true);
console.log('imgurl=' + imgurl);
imos[eval(-1 + imos.length)].send(null);
} else {
imos.push(new Image());
imos[eval(-1 + imos.length)].title=imgurl;


imos[eval(-1 + imos.length)].onerror = function(event) {
var ttl=event.target.title;
alert('error with ' + ttl);
for (var iik=0; iik<tothers.length; iik++) {
if (tothers[iik].indexOf(ttl + '#') == 0) { tothers[iik]=''; }
}
}


imos[eval(-1 + imos.length)].onload = function(event) {
var sfx='';
var myc=document.getElementById('mycanvas');
var mycontx=myc.getContext('2d');
mycontx.drawImage(event.target,0,0);
var ttl=event.target.title;
for (var iik=0; iik<tothers.length; iik++) {
if (tothers[iik].indexOf(ttl + '#') == 0) { sfx='#' + tothers[iik].split('#')[1]; tothers[iik]=myc.toDataURL('image/png') + sfx; }
}
alert('no error with ' + event.target.title);
}


imos[eval(-1 + imos.length)].src=imgurl;
}
}

“; ?>

… showing some onreadystatechanged percolation of used defined XMLHttpRequest object data members coming into play, in our changed PHP tutorial_to_animated_gif.php inhouse animated GIF creator web application further to yesterday’s Animated GIF Slide QR Code and Webpage Screenshot URL Tutorial.


Previous relevant Animated GIF SVG Slide Tutorial is shown below.

Animated GIF SVG Slide Tutorial

Animated GIF SVG Slide Tutorial

The PHP GD library we use to help create animated GIFs (along with a whole lot of other help, it goes without saying) is not into vector graphics which is what …

  • Inkscape … as a vector graphics editor … and …
  • SVG … ie. Scalable Vector Graphics

… are really into … ooooohhh, aaaaahhhh … but luckily for us, the great ImageMagick offers functionality to convert a SVG image file into a PNG image file, via …

Non Windows Windows
convert infile.svg outfile.png magick.exe infile.svg outfile.png

… and we’re using that talent ImageMagick has to offer the user the chance, at any animated GIF slide textbox, the chance to enter encodeURIComponent and window.btoa sensitive entries whose (content) format could match (one of) …

… means by which a user can involve SVG input slides into their animated GIF creations in our changed PHP tutorial_to_animated_gif.php inhouse animated GIF creator web application further to yesterday’s Animated GIF Slide QR Code and Webpage Screenshot URL Tutorial.

Below is a new (PHP writes) Javascript iframe (iois object below) onload event function for recognizing hTTps://[HtmlWebpageWithSVG].html as above, and setting the iframe’s “src” attribute to its value …

<?php echo ”

var mm1='', mm2='', mm3='';
var gdgebimm='', gtval='', onealready='';
var tvals=[], thistval=0, thistdelim='', thistid='';


function latermm() {
maybemore(mm3.value, mm2, mm3);
mm1='';
mm2='';
mm3='';
}

function svgmmcallol(iois, tid) {
//alert('TID=' + tid);
var tval='', it=0, dgebimm='';
var tis=document.getElementById(tid);
thistid=tid;
tvals=[];
thistval=0;
thistdelim='';
if (iois != null) {
var aconto = (iois.contentWindow || iois.contentDocument);
if (aconto != null) {
if (aconto.document) { aconto = aconto.document; }
if (aconto.body != null) {
tval=aconto.body.innerHTML;
//alert('Tval=' + tval);
if (tval.indexOf(encodeURIComponent('data:image/svg+xml')) != -1) {
thistval=1;
tvals=tval.split(encodeURIComponent('data:image/svg+xml'));
thistdelim=encodeURIComponent('data:image/svg+xml');
//alert('thistdeliM=' + thistdelim);


tval='data:image/svg+xml' + decodeURIComponent(tvals[thistval].split(String.fromCharCode(34))[0].split(String.fromCharCode(39))[0].split(')')[0].split('&')[0].split('>')[0]);
//alert('tvAl=' + tval);
//alert('tId=' + tid);

mm1=tval;
mm2=tid;
mm3=document.getElementById(tid.replace(/^slideshow1$/g,'slideshow'));
dgebimm='<iframe style=display:none; onload=mmcallol(this); src=\"' + '/PHP/fgc/index.php?askfor=' + encodeURIComponent(tval) + '\"></iframe>';
if (eval('' + dgebimm.length) > 800) {
document.getElementById('myaskfor').value=tval;
document.getElementById('saskfor').click();
} else {
document.getElementById('mmcall').innerHTML=dgebimm;
}
//setTimeout(latermm, 9000);
return '';
} else if (tval.indexOf('data:image/svg+xml') != -1) {
thistval=1;
tvals=tval.split('data:image/svg+xml');
thistdelim='data:image/svg+xml';
tval='data:image/svg+xml' + tvals[thistval].split(String.fromCharCode(34))[0].split(String.fromCharCode(39))[0].split(')')[0].split('&')[0].split('>')[0];

mm1=tval;
mm2=tid;
mm3=document.getElementById(tid.replace(/^slideshow1$/g,'slideshow'));
dgebimm='<iframe style=display:none; onload=mmcallol(this); src=\"' + '/PHP/fgc/index.php?askfor=' + encodeURIComponent(tval) + '\"></iframe>';
if (eval('' + dgebimm.length) > 800) {
document.getElementById('myaskfor').value=tval;
document.getElementById('saskfor').click();
} else {
document.getElementById('mmcall').innerHTML=dgebimm;
}
//setTimeout(latermm, 9000);
return '';
} else if (tval.indexOf(encodeURIComponent('<svg')) != -1 || tval.indexOf(encodeURIComponent('<SVG')) != -1) {
thistval=1;
if (tval.indexOf(encodeURIComponent('<svg')) != -1) {
tvals=tval.split(encodeURIComponent('<svg'));
thistdelim=encodeURIComponent('<svg');
tval='data:image/svg+xml;utf8,<svg' + decodeURIComponent(tvals[thistval].split(encodeURIComponent('</svg>'))[0]) + '</svg>';
} else {
tvals=tval.split(encodeURIComponent('<SVG'));
thistdelim=encodeURIComponent('<SVG');
tval='data:image/svg+xml;utf8,<SVG' + decodeURIComponent(tvals[thistval].split(encodeURIComponent('</SVG>'))[0]) + '</SVG>';
}
mm1=tval;
mm2=tid;
mm3=document.getElementById(tid.replace(/^slideshow1$/g,'slideshow'));
dgebimm='<iframe style=display:none; onload=mmcallol(this); src=\"' + '/PHP/fgc/index.php?askfor=' + encodeURIComponent(tval) + '\"></iframe>';
if (eval('' + dgebimm.length) > 800) {
document.getElementById('myaskfor').value=tval;
document.getElementById('saskfor').click();
} else {
document.getElementById('mmcall').innerHTML=dgebimm;
}
//setTimeout(latermm, 9000);
return '';
} else if (tval.indexOf(window.btoa('<svg')) != -1 || tval.indexOf(window.btoa('<SVG')) != -1) {
thistval=1;
if (tval.indexOf(window.btoa('<svg')) != -1) {
tvals=tval.split(window.btoa('<svg'));
thistdelim=window.btoa('<svg');
tval='data:image/svg+xml;base64,' + window.btoa('<svg') + tvals[thistval].split(window.btoa('</svg>'))[0] + window.btoa('</svg>');
} else {
tvals=tval.split(window.btoa('<SVG'));
thistdelim=window.btoa('<SVG');
tval='data:image/svg+xml;base64,' + window.btoa('<SVG') + tvals[thistval].split(window.btoa('</SVG>'))[0] + window.btoa('</SVG>');
}
mm1=tval;
mm2=tid;
mm3=document.getElementById(tid.replace(/^slideshow1$/g,'slideshow'));
dgebimm='<iframe style=display:none; onload=mmcallol(this); src=\"' + '/PHP/fgc/index.php?askfor=' + encodeURIComponent(tval) + '\"></iframe>';
if (eval('' + dgebimm.length) > 800) {
document.getElementById('myaskfor').value=tval;
document.getElementById('saskfor').click();
} else {
document.getElementById('mmcall').innerHTML=dgebimm;
}
//setTimeout(latermm, 9000);
return '';
} else if (tval.toLowerCase().indexOf('<svg') != -1) {
if (tval.indexOf('<svg') != -1) {
thistdelim='<svg';
tval='data:image/svg+xml;utf8,<svg' + tvals[thistval].split('</svg>')[0] + '</svg>';
} else {
thistdelim='<SVG';
tval='data:image/svg+xml;utf8,<SVG' + tvals[thistval].split('</SVG>')[0] + '</SVG>';
}
//alert('Thistdelim=' + thistdelim);
tvals=tval.split('<svg');
thistval=1;
//alert('1:tval=' + tval);
mm1=tval;
mm2=tid;
mm3=document.getElementById(tid.replace(/^slideshow1$/g,'slideshow'));
dgebimm='<iframe style=display:none; onload=mmcallol(this); src=\"' + '/PHP/fgc/index.php?askfor=' + encodeURIComponent(tval) + '\"></iframe>';
//alert('2:tval=' + tval);
if (eval('' + dgebimm.length) > 800) {
//alert('0: ' + dgebimm);
document.getElementById('myaskfor').value=tval;
document.getElementById('saskfor').click();
} else {
//alert('1: ' + dgebimm);
document.getElementById('mmcall').innerHTML=dgebimm;
}
//alert('3:tval=' + tval);
//setTimeout(latermm, 9000);
return '';
}
}
}
}
}

“; ?>


Previous relevant Animated GIF Slide QR Code and Webpage Screenshot URL Tutorial is shown below.

Animated GIF Slide QR Code and Webpage Screenshot URL Tutorial

Animated GIF Slide QR Code and Webpage Screenshot URL Tutorial

We wanted, today, to channel the (cruel might say “warped”) thinking behind the recent URL …

  1. interactive entry of absolute URL starting with HtTp means you want a QR Code … and …
  2. interactive entry of absolute URL starting with hTtP means you want (to involve, along the line, creating an animated QR Code scenario) a Webpage Screenshot

… we last talked about at Circular Text Around Media Animated QR Code Tutorial, because we feel this is actually a good inhouse idea to hang on to as a principle. Why?! Glad you asked. It is another way to …

  • end up with an image …
  • from any old absolute (but we have not yet researched ? and & get argument(s) regarding) URL

… really suiting the purpose of today’s work, that being the integration of this idea into our changed PHP tutorial_to_animated_gif.php inhouse animated GIF creator web application we last talked about at PdfImages PDF Output Media Zipping via PHP Tutorial. After all, an animated GIF slide is also an image, and it could be used in this way, to …

  1. create animated GIF of QR Code means by which a smart device user using their Camera might navigate to a series of interesting webpage(s) … or …
  2. create animated GIF of “current snapshot looks” of a series of URLs of interest (with even more currency than Google Earth shows your place!)

It might be you design an animated GIF chapter of slides and always want to follow it up with a “further reading” webpage you could present as a QR Code or Webpage Screenshot.

Anyway, at the “onblur” event Javascript function logic we intervened to end up with an image/png data URI substitute for the HtTp or hTtP URL the user enters to re-enter the normal animated GIF image definition workflow of the animated GIF creator …

<?php echo ”

var mm1='', mm2='', mm3='';


function latermm() {
maybemore(mm3.value, mm2, mm3);
mm1='';
mm2='';
mm3='';
}

function maybemore(tval, tid, tis) {
var newi=null, fo=null;
var inmb=0;
if (tval.indexOf('HtTp') == 0) {
mm1=tval;
mm2=tid;
mm3=tis;
document.getElementById('mmcall').innerHTML='<iframe style=display:none; onload=mmcallol(this); src=\"' + '/PHP/fgc/index.php?justcontent=&askfor=' + encodeURIComponent(document.URL.split('//')[0] + '//chart.googleapis.com/chart?chs=300x300&cht=qr&chl=' + encodeURIComponent('http' + encodeURIComponent(tval.substring(4).replace('S:','s:'))) + '&choe=UTF-8') + '\"></iframe>';
//setTimeout(latermm, 9000);
return '';
} else if (tval.indexOf('hTtP') == 0) {
mm1=tval;
mm2=tid;
mm3=tis;
document.getElementById('mmcall').innerHTML='<iframe style=display:none; onload=mmcallol(this); src=\"' + '/PHP/fgc/index.php?askfor=&askyou=' + encodeURIComponent('http' + tval.substring(4).replace('S:','s:')) + '\"></iframe>';
//setTimeout(latermm, 9000);
return '';
}

// rest of maybemore follows ...
}

“; ?>

… to help introduce this new animated GIF slide functionality arrangement.

If this was interesting you may be interested in this too.


If this was interesting you may be interested in this too.


If this was interesting you may be interested in this too.

This entry was posted in Ajax, eLearning, Event-Driven Programming, Tutorials and tagged , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , . Bookmark the permalink.

Leave a Reply

Your email address will not be published. Required fields are marked *

You may use these HTML tags and attributes: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <strike> <strong>