Emoji Image Creator or Media Paster Multiple Copy Synchronize Tutorial
โœ‚๐Ÿƒ๐Ÿพโ€โ™€๏ธ๐Ÿƒ๐Ÿผโ€โ™‚๏ธ
๐Ÿ“–

Emoji Image Creator or Media Paster Multiple Copy Background Tutorial

Emoji Image Creator or Media Paster Multiple Copy Synchronize Tutorial

Adding onto yesterdayโ€™s Emoji Image Creator or Media Paster Multiple Copy Background Tutorial โ€œMultiple Copy/Paste of Filesโ€ improvements, today weโ€™re getting more into the head of a user of the โ€œCopy Mediaโ€ button encouraging the Copy of files over to the โ€œPasteโ€ area div element via macOS Finder or Windows Explorer, in the sense that โ€ฆ

  • programmatically weโ€™ve deemed it the web applicationโ€™s role, if possible, to synchronize audio/video media โ€œplayโ€ โ€ฆ if โ€ฆ
  • the user has gone to the trouble to Copy over more than one audio/video file sets of data โ€ฆ presumably because (though we do not look into, or enforce, this) โ€ฆ
  • video has just visuals and the audio could be a voiceover for that video, or perhaps two audios are two voices that sound good merged (ie. synchronized), or perhaps two videos played together synchronously make sense explaining an issue or product

โ€ฆ all evidential to your regular reader of this blogโ€™s continuation with โ€ฆ



Media Synchronization

โ€ฆ that a lot of you readers out there will know is a near impossibility with mobile devices. Those readers who study โ€œthe masochism of RJM Programming regarding media synchronizationโ€ will be interested that we exhausted another avenue of thought. We played around (with some small proof of concept HTML) โ€ฆ

  • nested an โ€œaudioโ€ element within a โ€œvideoโ€ element โ€ฆ


    <video id=myvideo controls><source type='video/mp4' src='ants.m4v'></source><audio id=myaudio controls><source type='audio/mp4' src='audiocapture.m4a'></source></audio></video>


    โ€ฆ and then clicked โ€œplayโ€ for either โ€ฆ no go regarding synchronization
  • nested a โ€œvideoโ€ element within a โ€œaudioโ€ element and then clicked โ€œplayโ€ for either โ€ฆ no go regarding synchronization
  • nested an โ€œaudioโ€ elementโ€™s โ€œsourceโ€ subelement within a โ€œvideoโ€ element and then clicked โ€œplayโ€ for either โ€ฆ no go regarding synchronization
  • nested a โ€œvideoโ€ elementโ€™s โ€œsourceโ€ subelement within an โ€œaudioโ€ element and then clicked โ€œplayโ€ for either โ€ฆ no go regarding synchronization

โ€ฆ at least also trying to see whether a click by a parent can flow through to a media element to perhaps satisfy the iOS need for a click to instigate (media) โ€œplayโ€. Ooooohhhh well!

But back in โ€œnon-mobile landโ€ we change the code to entrench that hosting โ€œdivโ€ element (of potential media elements) โ€œonclickโ€ logic to point to the changed Javascript โ€œfunction predotogglei()โ€ below โ€ฆ



var medialist=[];

var thismediaid='';




function divclick() {

if (eval('' + medialist.length) > 1) {

for (var iu=0; iu<medialist.length; iu++) {

//document.title+=' ' + medialist[iu].id;

if (eval(iu % 2) == 0 || 1 == 1) {

medialist[iu].play();

} else {

medialist[iu].autoplay=true; //play();

medialist[iu].load();

}

}

}

}




function predotogglei() {

var toti=0;

var cumy=0;

var ims=document.getElementsByTagName('img');

var zrect=null;

var yrect=document.getElementById('editor').getBoundingClientRect();

divclick();

bpos=''; //0px 0px';

bsiz=''; //0px 0px';

for (var jjims=0; jjims<ims.length; jjims++) {

if (('' + ims[jjims].className) == 'togglei') {

toti++;

}

}

for (var jims=0; jims<ims.length; jims++) {

if (('' + ims[jims].className) == 'togglei') {

if (bpos == '') {

bpos='0px 0px';

zrect=ims[jims].getBoundingClientRect();

cumy+=eval('' + zrect.height);

bsiz='auto ' + zrect.height + 'px';

} else {

bpos+=',0px ' + cumy + 'px';

zrect=ims[jims].getBoundingClientRect();

cumy+=eval('' + zrect.height);

bsiz+=',auto ' + zrect.height + 'px';

}

}

}

if (bpos != '') {

document.getElementById('editor').style.backgroundPosition=bpos;

document.getElementById('editor').style.backgroundSize=bsiz;

}

}

โ€ฆ is made useful via changed โ€œcollection (of media) logicโ€ Javascript as per (an โ€œaudioโ€ element example) โ€ฆ

<?php echo โ€


thismediaid='media' + medialist.length;

document.getElementById('editor').innerHTML+='<audio id=' + thismediaid + ' controls><source type=\"' + ('' + btypes[curnum]) + '\" src=\"' + duis + '\"></source></audio>';

medialist.push(document.getElementById(thismediaid));

if (eval('' + medialist.length) > 1) { document.getElementById('editor').title='Click me for synchronized audio/video play where allowed.'; }



โ€œ; ?>

And so ourchanged PHP emoji_imageโšซphp liveโœ‚run chips away at the implications of โ€œMultiple Copy/Paste media file setsโ€ in terms of trying to synchronize the โ€œplayโ€ of (albeit probably only non-mobile) media files that benefit from synchronization, because we have assumed our users know what they are doing?! And donโ€™t they just!?



Previous relevant Emoji Image Creator or Media Paster Multiple Copy Background Tutorial is shown below.

Emoji Image Creator or Media Paster Multiple Copy Background Tutorial

Emoji Image Creator or Media Paster Multiple Copy Background Tutorial

With the recent Emoji Image Creator or Media Paster Multiple Copy Tutorialโ€˜s introduction of โ€ฆ

  • allow for Copy of multiple files in the jQuery logic โ€ฆ and today we โ€ฆ
  • add a new button โ€œCopy Mediaโ€ for the user who will Copy multiple image/audio/video media
  • add โ€œPaste hereโ€ to table cellโ€™s div contenteditable=true element in which the user should Paste their data
  • allow for background images to this Paste cell โ€ฆ whose โ€ฆ
  • corresponding real img elements for each background image, when clicked, can download that image data for the user

Regarding the positioning of these multiple background images we need to reference those real img element coreespondents, as per the new Javascript function โ€ฆ



function predotogglei() {

var toti=0;

var cumy=0;

var ims=document.getElementsByTagName('img');

var zrect=null;

var yrect=document.getElementById('editor').getBoundingClientRect();

bpos=''; //0px 0px';

bsiz=''; //0px 0px';

for (var jjims=0; jjims<ims.length; jjims++) {

if (('' + ims[jjims].className) == 'togglei') {

toti++;

}

}

for (var jims=0; jims<ims.length; jims++) {

if (('' + ims[jims].className) == 'togglei') {

if (bpos == '') {

bpos='0px 0px';

zrect=ims[jims].getBoundingClientRect();

cumy+=eval('' + zrect.height);

bsiz='auto ' + zrect.height + 'px';

} else {

bpos+=',0px ' + cumy + 'px';

zrect=ims[jims].getBoundingClientRect();

cumy+=eval('' + zrect.height);

bsiz+=',auto ' + zrect.height + 'px';

}

}

}

document.getElementById('editor').style.backgroundPosition=bpos;

document.getElementById('editor').style.backgroundSize=bsiz;

}

Yes, you guessed it. Thereโ€™s still far more to what we might do regarding reading a userโ€™s mind when they copy and paste multiple files over, and that is still a work in progress, along with cross-browser issues and how to handle multiple background or border image usage, but for now, feel free to try this new multiple copy/paste background image download functionality, which exists in ourchanged PHP emoji_imageโšซphp liveโœ‚run, for yourself, again, in your yurt.


Previous relevant Emoji Image Creator or Media Paster Multiple Copy Tutorial is shown below.

Emoji Image Creator or Media Paster Multiple Copy Tutorial

Emoji Image Creator or Media Paster Multiple Copy Tutorial

Could there be another โ€œonions of the 4th dimensionโ€ amendment left that could help our project, the โ€œEmoji Image (and media)โ€ web application of yesterdayโ€™s Emoji Image Creator or Media Paster Aesthetics Tutorial? We think so.

You see, when we added that Audio and/or Video media functionality, did anything occur to you regarding โ€ฆ

  • the procedure recommended to do Audio and/or Video data โ€ฆ or even โ€ฆ
  • the very idea, anyway

? Itโ€™s pretty optimistic thinking users would just select a single Audio or Video file to copy over to our web application, and fit in with its (previous) โ€œlimited viewโ€. Pretty obviously, weโ€™d like to cater for multiple file selections both in the Audio or Video scenario there, plus the idea of a user ignoring Google Pagespeed (third party) help, and opting to use macOS Finder or Windows Explorer to select multiple image files, or various media mix combinations.

Do you see what a Pandoraโ€™s Box we are opening ourselves up to with this? Yes, it will take more than today to get this Multiple Copy (and Multiple Paste) functionality to be smoothly integrated. Our biggest start down that road, though, is that jQuery access of the HTML5 File API โ€œonloadendโ€ arrangements. If you just think the โ€œone fileโ€ usage here will work for โ€œmultiple fileโ€ usage, the way it was, think again. We did, with the web application of Image/PDF and Audio/Video Supervised Rotation Tutorial, luckily, as a conduit to a reunderstanding of that more complex jQuery and File API Javascript required now, for this โ€ฆ

<?php echo โ€œ


var btype='';

var origdu='';

var origwo=null;

var origdus=[];

var btypes=[];

var curnum=0;

var curtot=0;

var fileReaders=[];

var imageFiles=[];

var curi=0;

var ii=0;




$(document).ready(function() {

$('#editor').on('paste', function(e) {

var i = 0;

ii = -1;

var fileReader = null;

var imageFile = null;


var orgEvent = e.originalEvent;

curtot = eval('' + orgEvent.clipboardData.items.length);

console.log('curtot=' + curtot);

for (i = 0; i < orgEvent.clipboardData.items.length; i++) {

console.log('i=' + i + ' of ' + curtot + ' and kind=' + orgEvent.clipboardData.items[i].kind);

if (orgEvent.clipboardData.items[i].kind == \"file\" && (i > 0 || (('' + orgEvent.clipboardData.items[i].type).substring(0,6) == \"" . $iimage . "/\" || ('' + orgEvent.clipboardData.items[i].type).substring(0,6) == \"" . $iaudio . "/\" || ('' + orgEvent.clipboardData.items[i].type).substring(0,6) == \"" . $ivideo . "/\"))) {

ii++;

imageFile = orgEvent.clipboardData.items[i].getAsFile();

imageFiles.push(imageFile);

fileReader = new FileReader();

fileReaders.push(fileReader);

btype=('' + orgEvent.clipboardData.items[i].type);

btypes.push(btype);

curi=eval(-1 + fileReaders.length);



if (eval('' + curtot) > 1) {



fileReaders[ii].onloadend = (function(mfile) {

return function(evt) {

if (evt.target.readyState == FileReader.DONE) { // DONE == 2

origdu=evt.target.result;

origdus.push(origdu);

$('#result').html(document.getElementById('result').innerHTML + evt.target.result);

andthen(mfile.type);

} };

})(imageFiles[ii]);

fileReaders[ii].readAsDataURL(imageFiles[ii]);

if (eval(1 + i) == eval('' + curtot)) { break; }



} else {




fileReader.onloadend = function() {

origdu=fileReader.result;

origdus.push(origdu);

$('#result').html(document.getElementById('result').innerHTML + fileReader.result);

andthen(btypes[curi]);

}



fileReader.readAsDataURL(imageFile);

if (eval(1 + i) == eval('' + curtot)) { break; }

}

} else if (orgEvent.clipboardData.items[i].kind == \"string\") { // && (('' + orgEvent.clipboardData.items[i].type).substring(0,6) == \"" . $iimage . "/\" || ('' + orgEvent.clipboardData.items[i].type).substring(0,6) == \"" . $iaudio . "/\" || ('' + orgEvent.clipboardData.items[i].type).substring(0,6) == \"" . $ivideo . "/\")) {

btype=('' + orgEvent.clipboardData.items[i].type);

btypes.push(btype);

setTimeout(prethen, 2000);

}

}

});

});


โ€œ; ?>

Now thereโ€™s far more to what we might do regarding reading a userโ€™s mind when they copy and paste multiple files over, and that will be a work in progress, along with cross-browser issues and how to handle multiple background or border image usage, but for now, feel free to try this new multiple copy/paste functionality, which exists in ourchanged PHP emoji_imageโšซphp liveโœ‚run, for yourself, again, in your yurt.


Previous relevant Emoji Image Creator or Media Paster Aesthetics Tutorial is shown below.

Emoji Image Creator or Media Paster Aesthetics Tutorial

Emoji Image Creator or Media Paster Aesthetics Tutorial

If you have been following our latest โ€œEmoji Image (and other media)โ€ project of yesterdayโ€™s Emoji Image Creator or Media Paster Download Tutorial you will know we have two (publicly displaying) โ€œincarnationsโ€ of the inhouse bit of the PHP webpage โ€ฆ

  1. first incarnation asks for user input via user interaction โ€ฆ including storming out โ€ฆ
  2. second incarnation shows results and now allows for downloading results as HTML snippets

โ€ฆ and today we try to minimize the numbers of people storming out we hope. This is something running in our favour here, as these changes concern the first incarnation above.

  • if you have a webpage waiting for user interactivity it doesnโ€™t matter โ€ฆ
  • if you load it with display intensive CSS (such as our โ€œglowโ€ animations) โ€ฆ it doesnโ€™t matter โ€ฆ youโ€™re waiting there anyway โ€ฆ plus you are self-explaining

And there is not much better, to our mind, for โ€œself-explainingโ€ and helping that little bit with internationalization, of your web application than to โ€ฆ

  • use emojis โ€ฆ and fortunately for us with this web application here โ€ฆ
  • involve โ€œend resultsโ€ of what your web application might achieve โ€ฆ and fortunately for us with this web application that is emoji image border images and background images

A new block of CSS for that first incarnation is our progress, today, then (where data uri have been [nicknamed] below) โ€ฆ

<?php echo โ€


<style>



.cglow {

box-shadow-bottom-right-radius: 50%; // thanks to https://stackoverflow.com/questions/2714765/using-border-radius-and-box-shadow-together-css

box-shadow-bottom-left-radius: 50%;

box-shadow-top-right-radius: 50%;

box-shadow-top-left-radius: 50%;

-webkit-animation: cglow 1s ease-in-out infinite alternate;

-moz-animation: cglow 1s ease-in-out infinite alternate;

animation: cglow 1s ease-in-out infinite alternate;

-webkit-border-radius: 50%;

border-radius: 50%;

}



.glow {

-webkit-animation: glow 1s ease-in-out infinite alternate;

-moz-animation: glow 1s ease-in-out infinite alternate;

animation: glow 1s ease-in-out infinite alternate;

border: 30px solid white;

padding: 25px;

border-image:URL([owlToImageEmojiDataUri]);

border-image-slice: 45% 5%;

border-image-repeat: round;

text-align: center;

}



/* Thanks to https://www.w3schools.com/howto/tryit.asp?filename=tryhow_css_glowing_text */



@-webkit-keyframes cglow {

from {

box-shadow: 0 0 3px #fff, 0 0 5px #fff, 0 0 37px #e60073, 0 0 9px #e60073, 0 0 11px #e60073, 0 0 13px #e60073, 0 0 15px #e60073;

box-shadow-bottom-right-radius: 50%; // thanks to https://stackoverflow.com/questions/2714765/using-border-radius-and-box-shadow-together-css

box-shadow-bottom-left-radius: 50%;

box-shadow-top-right-radius: 50%;

box-shadow-top-left-radius: 50%;

}



to {

box-shadow: 0 0 24px #fff, 0 0 6px #ff4da6, 0 0 8px #ff4da6, 0 0 10px #ff4da6, 0 0 12px #ff4da6, 0 0 14px #ff4da6, 0 0 16px #ff4da6;

box-shadow-bottom-right-radius: 50%; // thanks to https://stackoverflow.com/questions/2714765/using-border-radius-and-box-shadow-together-css

box-shadow-bottom-left-radius: 50%;

box-shadow-top-right-radius: 50%;

box-shadow-top-left-radius: 50%;

}

}



@-webkit-keyframes glow {

from {

box-shadow: 0 0 3px #fff, 0 0 5px #fff, 0 0 37px #e60073, 0 0 9px #e60073, 0 0 11px #e60073, 0 0 13px #e60073, 0 0 15px #e60073;

}



to {

box-shadow: 0 0 24px #fff, 0 0 6px #ff4da6, 0 0 8px #ff4da6, 0 0 10px #ff4da6, 0 0 12px #ff4da6, 0 0 14px #ff4da6, 0 0 16px #ff4da6;

}

}



input[type=text] {

padding: 25px 0;

}



input[type=submit] {

padding: 10px 10px 10px 10px;

width: 25%;

height: 100px;

background:linear-gradient(rgba(255,255,255,0.8),rgba(255,255,255,0.8)),URL([owlToImageEmojiDataUri]);

background-size: cover;

background-repeat: no-repeat;

border: 2px solid yellow;

}



input[type=button] {

padding: 10px 10px 10px 10px;

width: 25%;

height: 100px;

}



#video {

background:linear-gradient(rgba(255,255,255,0.8),rgba(255,255,255,0.8)),URL([videoEmojiDataUri]);

background-size: cover;

background-repeat: no-repeat;

border: 2px solid yellow;

}



#audio {

background:linear-gradient(rgba(255,255,255,0.8),rgba(255,255,255,0.8)),URL([audioEmojiDataUri]);

background-size: contain;

background-repeat: no-repeat;

border: 2px solid yellow;

}



</style>


โ€œ; ?>

Try this new look functionality which exists in ourchanged PHP emoji_imageโšซphp liveโœ‚run, for you to try all this for yourself, yet again.


Previous relevant Emoji Image Creator or Media Paster Download Tutorial is shown below.

Emoji Image Creator or Media Paster Download Tutorial

Emoji Image Creator or Media Paster Download Tutorial

Yesterdayโ€™s Emoji Image Creator or Media Paster Tutorial continued our โ€œEmoji Image (and media)โ€ web application projectโ€™s progress, that we see in the analogous terms below โ€ฆ

Project Analogy
First webpage incarnation with textbox and textarea and buttons is displayed. The user is shown the menu for goods creation.
On first webpage incarnation user assembles emojis and/or text into textbox and textarea and clicks appropriate button, as required. Goods are imagined by prospective user to their requirements.
User copies from third party resource and pastes (that copy) into second webpage incarnation table cell. Goods are created by prospective user to their requirements with help of third party resources.
Web application reworks media into border and background element enhancements on second webpage incarnation. Goods are packed into containers and shipped to user port.
? User gets goods off ship in port ready for personal use.

What ? (dare we say) โ€œonions of the 4th dimensionโ€ amendment could help our project? Anyone, anyone? Yes, Tomas Norstrรถm to get data from โ€œremote woooooorrrrrrllllldโ€ to โ€œlocal woooooorrrrrrllllldโ€ you โ€ฆ

download

And in order for this to โ€œvalue addโ€ letโ€™s arrange for the user to be able to โ€œdownloadโ€ second webpage incarnation elements of interest, by clicking them, after initially (just) displaying them. We do this for an โ€œexistent element content of interestโ€ called [contentOfInterest] via the nesting of that [contentOfInterest] as per โ€ฆ



<a download style="cursor:pointer;text-decoration: underline overline dotted red;" target=_blank href="data:text/html,[htmlWorkedContentOfInterest]">[contentOfInterest]</a>

โ€ฆ as the concept we match to the new Javascript function โ€œactualityโ€ โ€ฆ

<?php echo โ€


function downloaditize(ois) {

var xrect=ois.getBoundingClientRect();

var fromc=\" style='\";

var toc=\" style='width:\" + xrect.width + \"px;height:\" + xrect.height + \"px;\";

var ihis='', stys=[];

var wasihis=ois.innerHTML;

if (wasihis.indexOf(' download') == -1) {

if (('' + ois.id).indexOf('borderimg') == 0) {

ihis='<html><body' + toc + \"'\" + '>' + ois.innerHTML.replace('[asBelow]', ('data:' + document.getElementById('result').innerHTML.split('data:')[1].split('</')[0].split(')')[0])).replace(' transparent',' white') + '</body></html>';

while (ihis.indexOf(String.fromCharCode(34)) != -1) {

ihis=ihis.replace(String.fromCharCode(34),String.fromCharCode(39));

}

while (wasihis.indexOf(String.fromCharCode(34)) != -1) {

wasihis=wasihis.replace(String.fromCharCode(34),String.fromCharCode(39));

}

//console.log(wasihis);

//console.log('<a download style=\"cursor:pointer;text-decoration: underline overline dotted red;\" target=_blank href=\"data:text/html,' + wasihis.replace(/\<\;/g,'<').replace(/\>\;/g,'>').replace('[asBelow]', document.getElementById('result').innerHTML).replace(' transparent',' white') + '\" title=\"Download here\">' + wasihis + '</a>');

ois.innerHTML='<a download style=\"cursor:pointer;text-decoration: underline overline dotted red;\" target=_blank href=\"data:text/html,' + wasihis.replace(/\<\;/g,'<').replace(/\>\;/g,'>').replace('[asBelow]', document.getElementById('result').innerHTML).replace(' transparent',' white') + '\" title=\"Download here\">' + wasihis + '</a>';

} else {

if (('' + ois.id) == 'result') {

ihis='<html><body>' + ois.outerHTML.replace('[asBelow]', ('data:' + document.getElementById('result').innerHTML.split('data:')[1].split('</')[0].split(')')[0])).replace(' transparent',' white').replace(' title=', ' style=').replace('{',' ').replace('}',' ').replace('#' + ('' + ois.id),' ') + '</body></html>';

} else {

ihis='<html><body><table><tr>' + ois.outerHTML.replace('[asBelow]', document.getElementById('result').innerHTML).replace(' transparent',' white').replace(' title=', ' style=').replace('{',' ').replace('}',' ').replace('#' + ('' + ois.id),' ') + '</tr></table></body></html>';

}

while (ihis.indexOf(String.fromCharCode(34)) != -1) {

ihis=ihis.replace(String.fromCharCode(34),String.fromCharCode(39));

}

stys=ihis.split(\"' style='\");

if (stys.length == 3) {

ihis=ihis.replace(\"' style='\" + stys[2], \" \" + stys[2]);

}

if (('' + ois.id) != 'result') {

console.log('<a download style=\"cursor:pointer;text-decoration: underline overline dotted red;\" target=_blank href=\"data:text/html,' + ihis.replace(fromc,toc) + '\" title=\"Download here\">' + wasihis + '</a>');

}

ois.innerHTML='<a download style=\"cursor:pointer;text-decoration: underline overline dotted red;\" target=_blank href=\"data:text/html,' + ihis.replace(fromc,toc) + '\" title=\"Download here\">' + wasihis + '</a>';

}

}

}


โ€œ; ?>

โ€ฆ making use of the โ€œtext/htmlโ€ mime type data uri alternative means of expressing HTML content (in special scenarios). Once in the โ€œlocal woooooorrrrrrllllldโ€ opportunities exist to play around with downloaded files and involve a local web server system such as the MAMP Apache/PHP/MySql local web server we cannot speak too highly, regarding.

This new downloading functionality exists in ourchanged PHP emoji_imageโšซphp liveโœ‚run for you to try all this for yourself, again.


Previous relevant Emoji Image Creator or Media Paster Tutorial is shown below.

Emoji Image Creator or Media Paster Tutorial

Emoji Image Creator or Media Paster Tutorial

Thinking about yesterdayโ€™s Emoji Image Creator CSS Background Image Tutorialโ€˜s โ€ฆ

  • existent Emoji Image creation functionality โ€ฆ the next โ€œonions of the 4th dimensionโ€ amendment could involve โ€ฆ
  • add Audio Copier and Paster functionality โ€ฆ and โ€ฆ
  • add Video Copier and Paster functionality โ€ฆ to round out what a lot of us see as the โ€œmedia setโ€ in the online woooooorrrrrllllld

With these last two, we pare down the workings and leave it up to the user to copy these Audio and/or Video media data via Finder (in macOS) or Windows Explorer (in Windows) as a โ€œreplacement widgetโ€ for the โ€œGoogle Pagespeedโ€ widget weโ€™ve coded for regarding (Emnoji) Image media work.

Most crucial in these changes were the Javascript jQuery (and PHP helping out) code changes โ€ฆ

<?php

$ei=โ€Emoji Imageโ€;
$cr=โ€Creatorโ€;
$imgw=โ€imageโ€;
$iimage=โ€imageโ€;
$iaudio=โ€ywnftโ€;
$ivideo=โ€ywnftโ€;
$gps=โ€window.open(\โ€https://developers.google.com/speed/pagespeed/insights/?url=http%3A%2F%2Fwww.rjmprogramming.com.au%2FPHP%2Femoji_image.php&tab=mobile\โ€,\โ€_blank\โ€,\โ€top=50,left=50,height=900,width=1300\โ€);โ€;

$hblurb=โ€Copy (Image) from Google PageSpeed
(thanks, and note to toggle between mobile and desktop tabs perhaps)
and Paste via macOS Alt-PrtScr Below (for Data URI as well)
or to an Image Editor that can Crop out Extraneous White Parts
or Resize Image and Save
(ready for Border Image or Background Image or just Image purposes)โ€;

if (isset($_GET[โ€˜audioโ€™])) {
$hblurb=โ€Copy Audio
via Finder or Windows Explorer
and come Back Here to Paste that Dataโ€;
$ei=โ€Audioโ€;
$cr=โ€Pasterโ€;
$imgw=โ€audioโ€;
$iaudio=โ€audioโ€;
$iimage=โ€ywnftโ€;
$ivideo=โ€ywnftโ€;
$gps=โ€โ€;
} else if (isset($_GET[โ€˜videoโ€™])) {
$hblurb=โ€Copy Video
via Finder or Windows Explorer
and come Back Here to Paste that Dataโ€;
$ei=โ€Videoโ€;
$cr=โ€Pasterโ€;
$imgw=โ€videoโ€;
$ivideo=โ€videoโ€;
$iaudio=โ€ywnftโ€;
$iimage=โ€ywnftโ€;
$gps=โ€โ€;
}


echo โ€œ



<script type='text/javascript'>



var done=false;

var btype='';



$(document).ready(function() {

$('#editor').on('paste', function(e) {

var orgEvent = e.originalEvent;

for (var i = 0; i < orgEvent.clipboardData.items.length; i++) {

if (orgEvent.clipboardData.items[i].kind == \"file\" && (('' + orgEvent.clipboardData.items[i].type).substring(0,6) == \"" . $iimage . "/\" || ('' + orgEvent.clipboardData.items[i].type).substring(0,6) == \"" . $iaudio . "/\" || ('' + orgEvent.clipboardData.items[i].type).substring(0,6) == \"" . $ivideo . "/\")) {

var imageFile = orgEvent.clipboardData.items[i].getAsFile();

var fileReader = new FileReader();

btype=('' + orgEvent.clipboardData.items[i].type);

fileReader.onloadend = function() {

$('#result').html(fileReader.result);

andthen(btype);

}

fileReader.readAsDataURL(imageFile);

break;

}

}

});

});



// lots more Javascript follows

</script>


โ€œ; ?>

This new audio and/or video media functionality exists in ourchanged PHP emoji_imageโšซphp liveโœ‚run for you to try all this for yourself.


Previous relevant Emoji Image Creator CSS Background Image Tutorial is shown below.

Emoji Image Creator CSS Background Image Tutorial

Emoji Image Creator CSS Background Image Tutorial

The recent โ€ฆ

โ€ฆ before we say โ€œBIyeโ€ to the Emoji Image themed blog postings here.

As many users will know, emojis can be the graphically-challenged userโ€™s ticket to โ€ฆ

  • personalization
  • graphical and aesthetic appeal of webpages
  • attracting attention to your content

โ€ฆ that is much easier than learning the graphical expertise Photoshop and Gimp usage encourages. But too much emoji usage can look a bit predictable too, so we are not discouraging you from learning any of those graphical expertise skills.

Emojis are limited from a lot of CSS styling border and background image usage, but we can convert those Emojis into images here, which is the gist of what we are on about here on this blog posting thread.

In order to show a bit of background image work we sprinkle the webpage with four CSS styling examples of usage (ordered from the top to bottom and left to right) โ€ฆ

<style>

  1. #hthree { background:linear-gradient(rgba(255,255,255,0.3),rgba(255,255,255,0.3)),URL([asBelow]); background-size:cover; background-repeat:no-repeat; }
  2. #thone { background:URL([asBelow]); background-repeat:no-repeat; }
  3. #thtwo { background:linear-gradient(rgba(255,255,255,0.3),rgba(255,255,255,0.3)),URL([asBelow]); background-repeat:repeat; }
  4. #result { background:linear-gradient(rgba(255,255,255,0.3),rgba(255,255,255,0.3)),URL([asBelow]); background-size:contain; background-repeat:no-repeat; }

</style>

โ€ฆ and added dynamically because โ€ฆ

  • <style> CSS </style> is not restricted to just <head></head> but can also work within <body></body> โ€ฆ and โ€ฆ
  • for that <body>[document.body.innerHTML]</body> usage Javascript (DOM, within document.body.innerHTML) can dynamically add the CSS styling at a time of the programmerโ€™s choosing

And so yet again, here is ourchanged PHP emoji_imageโšซphp liveโœ‚run for you to take up both the Border Emoji Image CSS Challenge and, now, Background Emoji Image CSS Challenge!

Did you know?

Thanks to this wonderful link we were able to get around our โ€œmobile platforms not showing our (independently tested that whitespace cropping was occurring whether in png format or in jpeg format) image CSS border image applicationsโ€ issue by changing the CSS โ€ฆ

From (suits non-mobile) To (better suiting mobile)
#borderimg1 {
border: 20px solid transparent;
}
#borderimg1 {
border: 20px solid white;
}
#borderimg2 {
border: 20px solid transparent;
}
#borderimg2 {
border: 20px solid white;
}


Previous relevant Emoji Image Creator CSS Border Image Tutorial is shown below.

Emoji Image Creator CSS Border Image Tutorial

Emoji Image Creator CSS Border Image Tutorial

Before building on the recent Emoji Image Creator Share Tutorial with progress (of a meaningful quality) regarding โ€ฆ

  • CSS Border Images (made from data-uri data of these recent Emoji Images) โ€ฆ we had to โ€œcrackโ€ โ€œthe ol'โ€ โ€ฆ
  • automating the cropping of bottom and right whitespace

โ€ฆ because you will find only the top border image bits โ€œfilled outโ€ if the imagery in the CSS โ€œborder-image:URL([data-uri data of these recent Emoji Images]);โ€ has a lopsided whitespace feel to it. PHP can easily do this out of the box from PHP 5.5 onwards via its GD library imagecropauto function. Alas, up at the RJM Programming domain we are on PHP 5.4 and so ended up being helped out enormously by the brilliant ideas on this wonderful link, thanks.

Okay, so we can arrive at a whitespace cropped Emoji Image data uri, what then? Well, we recommend you read โ€ฆ

โ€ฆ and we display a couple of examples of uses of Border Images using the resultant Emoji Image data uri you create.

So, are you ready for the challenge? Yet again, here is ourchanged PHP emoji_imageโšซphp liveโœ‚run for you to take up that Border Emoji Image CSS Challenge!


Previous relevant Emoji Image Creator Share Tutorial is shown below.

Emoji Image Creator Share Tutorial

Emoji Image Creator Share Tutorial

We have a couple of โ€œonions of the 4th dimensionโ€ amendments to yesterdayโ€™s Emoji Image Creator Primer Tutorial โ€ฆ

  • the display format scope of the Emoji Image Creator โ€œpaletteโ€ (โ€œshall we say now โ€ฆ eh wot โ€˜guvโ€) extends from single line of entry to be able to handle multiple lines of entry โ€ฆ and Emojis being text that means either โ€ฆ
    1. div contenteditable=true โ€ฆ but we have plumped for โ€ฆ
    2. textarea

    โ€ฆ means by which to make this thangthing happen manperson

  • the sharing scope of the Emoji Image Creator goes from โ€œkeeping everything to yourselfโ€ to โ€œsharing via Email (email client or Inline HTML Email) or SMSโ€

โ€ฆ your Emoji Image creations. And โ€ฆ

โ€œWhere do ya get it?โ€

โ€ฆ here? โ€ฆ or am I missing something? Canโ€™t be โ€ฆ Iโ€™m writing this.

Glad thatโ€™s over!

And back to matters at hand, how do we handle that โ€œrequireโ€ attribute weโ€™d placed on yesterdayโ€™s lonesome textbox? Well, we get around that by setting an empty textbox to a space should the user only enter Emoji data in that new textarea (that circumvents the โ€œrequireโ€ attribute validation restriction), and deploy logic that takes into account PHP variables where โ€ฆ

<?php


$gei="";

if (isset($_GET['emoji_textarea_image'])) {

$gei=str_replace("+"," ",urldecode($_GET['emoji_textarea_image']));

}




if (trim($gei) != "" || isset($_GET['emoji_image'])) {

if (trim($gei) == "") {

$gei=str_replace("+"," ",urldecode($_GET['emoji_image']));

} else if (isset($_GET['emoji_image'])) {

$pregei=str_replace("+"," ",urldecode($_GET['emoji_image']));

if (trim($pregei) != "") {

$pregei.="\n\n" . $gei;

$gei=$pregei;

}

}


file_put_contents('emoji_image.txt', str_replace(";","",str_replace("&#","",str_replace(";&#",".",$gei))) );

// more logic follows to continue the work below ...

}


?>

โ€ฆ PHP function trim comes to our aid, as it so often does in โ€œPHP landโ€ (or as String.trim() does in โ€œJavascript landโ€) with backward compatibility for dual purpose scenarios.

And again, here is ourchanged PHP emoji_imageโšซphp liveโœ‚run for you to retry, and perhaps, share!


Previous relevant Emoji Image Creator Primer Tutorial is shown below.

Emoji Image Creator Primer Tutorial

Emoji Image Creator Primer Tutorial

Weโ€™ve long eyed up the wish to have emojis (which you need to know are text (and this very fact is the reason for this whole project)) be involved with a border image or background image or just with some image in work developing web applications. And so we joined forces with (and thanks to) โ€ฆ

โ€ฆ along with โ€ฆ

  • textbox reachable โ€œEmoji and Symbolsโ€ menu to include Emoji characters (though we also accept Emoji CodePoint(s) too)
  • Copy and Paste technologies โ€ฆ
    1. Copy (Image) from Google PageSpeed
    2. Paste to HTML div contenteditable=true via Stack Overflow and jQuery
  • your own desktop Image Editors โ€ฆ for example โ€ฆ
    1. Gimp can Crop and Resize and Select to new Image via Copy then Paste
    2. Preview and Paintbrush (here on macOS) can Resize and Select to new Image via Copy then Paste

    โ€ฆ can help remove any extraneous whitespace coming off the Google PageSpeed Copy image

With all this help coming our way youโ€™d think we might get away just using HTML and Javascript, but no, we need PHP, we figure, using a web browser file to toggle between web application executions that have no arguments as either โ€ฆ

  • it means we display our inhouse interactive entry mode of use when that file does not exist โ€ฆ whereas โ€ฆ
  • we arrange it so that it is a call from Google PageSpeed when that file exists (as we morph inhouse content into a single p element containing the Emojis in such a scenario) as Google PageSpeed takes its screenwebpageshot

So here is our PHP emoji_imageโšซphp liveโœ‚run โ€ฆ

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.


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.


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.


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

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

Leave a Reply

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