We find curl to be that interesting PHP โmode of useโ hybrid of the involvement of โฆ
- HTTP protocol URLs
- command line
- interface to PHP exec
โฆ that might help you โlook back at yourself from outsideโ as we use it to interface to Google PageSpeed Insights webpage screenshot functionality (which can look at a designated URL and effectively screenshot it for you) โฆ thanks.
The URL โGETโ argument restriction of โonly ?โ first arguments, as with yesterdayโs Emoji Borders and Backgrounds QR Code Tutorial, comes into play interfacing to Google PageSpeed Insights webpage screenshot functionality.
We used to restrict our curl usage thinking to โonly ?โ first argument use too, arguing (with ourselves) that the Linux and Unix and macOS and Mac OS X โ&โ character command line meaning of โprocess in the backgroundโ would be a constraint. Of course it isnโt, because โฆ anyone, anyone? Yes, Henry, you should use a โcurlโ command line command, using double quotes, of the form โฆ
curl "https://www.rjmprogramming.com.au/PHP/canvas_svg.php?emoji=128248&iurl=two.jpg%23circle&css=opacity%3A0.9%3Bfont-size%3A20px%3B&textcss=text-shadow%3A%20-2px%202px%203px%20%23ff2d95%3B&ultext=Hello%250AThere"
โฆ and the โ&โโs are understood to be URL โGETโ argument delimiters, and not a โprocess in the backgroundโ designator.
And hereโs the thing exemplified above. The alternative file_get_contents PHP function cannot do that https: protocol type of URL, yet Google PageSpeed Insights webpage screenshot functionality demands such URLs โฆ hence the โcurlโ interest.
So try ourchanged PHP canvas_svgphp SVG
-> IMG -> CANVAS live run web application โฆ
<?php
$psbig='curl "https://pagespeedonline.googleapis.com/pagespeedonline/v5/runPagespeed/?url=' . str_replace('localhost:8888','www.rjmprogramming.com.au',$udirname) . 'canvas_svg.php&screenshot=true" > /tmp/pscs.xxx';
if (isset($_GET['justtheone']) && strpos(('' . $_SERVER['QUERY_STRING']), '&') === false) {
header('Location: ' . str_replace('http:','',$udirname . 'canvas_svg.php' . '?' . urldecode(str_replace('justtheone=','',$_GET['justtheone']))));
exit;
} else if (('' . $_SERVER['QUERY_STRING']) != '') {
$qrbig="//chart.googleapis.com/chart?chs=300x300&cht=qr&chl=" . $udirname . "canvas_svg.php?justtheone=" . urlencode($_SERVER['QUERY_STRING']) . "&choe=UTF-8";
$psbig='curl "https://pagespeedonline.googleapis.com/pagespeedonline/v5/runPagespeed/?url=' . str_replace('localhost:8888','www.rjmprogramming.com.au',$udirname) . 'canvas_svg.php?justtheone=' . urlencode( str_replace('howpagespeedseesme=y&','', str_replace('?howpagespeedseesme=y','', str_replace('&howpagespeedseesme=y','', $_SERVER['QUERY_STRING']))) ) . '&screenshot=true" > /tmp/pscs.xxx';
}
$extis='.xxx';
if (strpos(('' . $_SERVER['QUERY_STRING']), 'howpagespeedseesme=') !== false) {
if (file_exists('/tmp/')) {
if (file_exists('/tmp/pscs.xxx')) {
unlink('/tmp/pscs.xxx');
}
}
exec($psbig);
while (!file_exists('/tmp/pscs' . $extis)) {
sleep(4);
}
while (filesize('/tmp/pscs' . $extis) == 0) {
sleep(4);
}
$scx=file_get_contents('/tmp/pscs' . $extis);
$scxs=explode('"screenshot":', $scx);
if (sizeof($scxs) > 1) {
$postscxs=explode('"data": ', $scxs[1]);
if (sizeof($postscxs) > 1) {
echo '<html><body><h2>How Google <a target=_blank title="Google PageSpeed Insights" href="https://pagespeed.web.dev/">PageSpeed Insights</a> Screenshots This ...</h2><img src=' . substr($postscxs[1],0,1) . explode(substr($postscxs[1],0,1), substr($postscxs[1],1))[0] . substr($postscxs[1],0,1) . '></img></body></html>';
} else {
echo '<html><body><h2>How Google <a target=_blank title="Google PageSpeed Insights" href="https://pagespeed.web.dev/">PageSpeed Insights</a> Screenshots This ...</h2><p>Sorry, resource exhausted. Could try again later.</p></body></html>';
}
} else {
echo '<html><body><h2>How Google <a target=_blank title="Google PageSpeed Insights" href="https://pagespeed.web.dev/">PageSpeed Insights</a> Screenshots This</h2><p>Sorry, resource exhausted. Could try again later.</p></body></html>';
}
exit;
}
?>
โฆ working with the new HTML div <div id=readyforiframe></div> element, along with <span title=โGoogle PageSpeed Insights webpage screenshot view of this web browser address URLโ onclick=โpsit();โ> 📸 </span> โemoji buttonโ in the HTML static code โฆ with associated Javascript function โฆ
<?php echo โ
function psit() {
document.getElementById('readyforiframe').style.width='100%';
document.getElementById('readyforiframe').style.height='900px';
document.getElementById('readyforiframe').innerHTML='<iframe style="width:100%;height:900px;" src="' + (document.URL.split('#')[0] + '&howpagespeedseesme=y').replace('.php&','.php?') + '"></iframe>';
location.href='#readyforiframe';
}
โ; ?>
Previous relevant Emoji Borders and Backgrounds Web Browser Tutorial is shown below.
Yesterdayโs Emoji Borders and Backgrounds Shape Sharing Tutorial had us sharing via email or SMS our โEmoji Borders and Backgroundsโ creations via inhouse organized arrangements. But many people are used to just right-clicking (for Windows) and two finger gesturing (for macOS and Mac OS X) on โฆ
- SVG
- IMG
- CANVAS
โฆ graphical elements, which can be made to โlookโ the same, and sort of โsuck it and seeโ as far as menu options presented, helping them out sharing graphical information. In many cases, users donโt care what form of element the image comes contained in. But, if you involve โbackground-imageโ CSS along the way to achieve a (consistent) โlookโ, as we had done before today, (some of) the output of those menu options could be lacking (because they look for โforeground dataโ), and so we do away with the need for a โbackground-imageโ โฆ
<?php
function ctoilater() {
img.src=canvas.toDataURL('data/png');
}
if ((iurl != '' && document.URL.indexOf('noimage') == -1) && emoji != '') {
//imgs[0].style.background='URL("' + iurl + '")';
//canvases[0].style.background='URL("' + iurl + '")';
if (emoji != '') {
imgs[0].style.backgroundPosition='20px 20px';
}
imgs[0].style.backgroundRepeat='no-repeat';
canvases[0].style.backgroundRepeat='no-repeat';
var newimg=document.createElement('img');
newimg.onload = function() {
// draw the image onto the canvas
if (document.URL.indexOf('emoji=') != -1) {
canvas.getContext('2d').drawImage(newimg, 20, 20);
} else {
canvas.getContext('2d').drawImage(newimg, 0, 0);
}
setTimeout(ctoilater, 3000);
}
newimg.src = iurl;
}
?>
โฆ look on the IMG and CANVAS element usage (as above) and use the great way a โฆ
- CANVAS can contain merged image data โฆ and a โฆ
- CANVAS can convert back to an image data URI
โฆ to mean IMG and CANVAS can end up united in a โreal image dataโ look and content, via SVG that can be made up of โฆ
- emoji TEXT
- user TEXT
- user IMAGE (like IMG)
- user shapes CIRCLE and/or ELLIPSE and/or RECT and/or LINE and/or POLYLINE and/or POLYGON โฆ and inhouse NOIMAGE
โฆ (SVG) โstreamsโ of graphical data.
We also needed to cater for that inhouse โNOIMAGEโ shape lack of IMAGE data in ourchanged PHP canvas_svgphp SVG
-> IMG -> CANVAS live run web application.
Did you know?
An example of how having web browser (right-clicking (for Windows) and two finger gesturing (for macOS and Mac OS X)) menu options be useful, consider an image menu option such as โCopy imageโ be used by the user. The user can compose their own (email client (or get to email client via all uppercase web application โtoโ email โaddressโ definition)) email then, and just Edit -> Paste the results, as an image, into the email body, ahead of sending off that email.
Previous relevant Emoji Borders and Backgrounds Shape Sharing Tutorial is shown below.
The code โshape shiftingโ of recent times morphs into โshape sharingโ together in amongst the parent users of our PHP tool โEmoji Borders and Backgroundsโ web application featuring in yesterdayโs Emoji Borders and Backgrounds Shape Numerics Tutorial.
We found the โSVG+XMLโ mimetype data not accepted by Gmail for an Inline HTML Email, so we have coded for the Downloadable HTML Attachment โway to goโ.
<?php
function emailit() {
var fbit='';
var tois=prompt('Please enter an email address to email to (all uppercase uses email client rather than PHP mail and all numerical sends an SMS).','');
if (tois == null) { tois=''; }
if (tois.trim() != '') {
if (tois.indexOf('@') != -1) {
if (tois.toUpperCase() == tois) {
document.getElementById('divemail').innerHTML='<a id=aemail style=display:none; href=mailto:' + tois + '?subject=My%20Emoji%20Border%20and%20Background%20Creation&body=' + encodeURIComponent(document.URL) + '>Email</a>';
//fbit=('' + document.getElementById('aemail').href).split('?')[1];
//document.getElementById('aemail').href='mailto:' + tois + '?' + fbit;
document.getElementById('aemail').click();
} else {
var zhr = new XMLHttpRequest();
var zform=new FormData();
if (1 == 2) { zform.append('inline', ''); }
zform.append('to', tois);
zform.append('subj', 'My Emoji Borders and Background Creation ... at [date] ...');
//alert(encodeURIComponent('<html><body><img src=\"<?php echo $bemb; ?>\"></img></body></html>'));
zform.append('tdhuhta', encodeURIComponent('<html>' + '<?php echo $headstyle; ?>' + '<body><img src="<?php echo $bemb; ?>"></img></body></html>'));
zhr.open('post', '//www.rjmprogramming.com.au/HTMLCSS/emailhtml.php', true);
zhr.send(zform);
alert('Email sent to ' + tois);
}
} else if (tois.replace(/0/g,'').replace(/1/g,'').replace(/2/g,'').replace(/3/g,'').replace(/4/g,'').replace(/5/g,'').replace(/6/g,'').replace(/7/g,'').replace(/8/g,'').replace(/9/g,'') == '') {
document.getElementById('divsms').innerHTML='<a id=asms style=display:none; href=sms:' + tois + '&body=' + encodeURIComponent(document.URL) + '>SMS</a>';
//document.getElementById('asms').href='sms:' + tois + '&body=' + encodeURIComponent(document.URL);
document.getElementById('asms').click();
}
}
}
?>
The inhouse slideshow PHP clonesโ changedassociated external Javascript inhouse_slideshowjs live
run is available.
The Image Map Grid changedPHP imagegridmapphpโs live
run is available.
And the โshape sharingโ goes on in our (third parent (to our PHP tool) โcab off the rankโ) SVG -> IMG -> CANVAS changedPHP canvas_svgphp live
run is available, being helped out by PHPtool code changes for inline_svgphpโs live
run.
Previous relevant Emoji Borders and Backgrounds Shape Numerics Tutorial is shown below.
If you are familiar with the geometry of shapes, it is full of numbers, with the implications as to how the shape is represented and displayed, that those numbers can affect. And so, onto yesterdayโs Emoji Borders and Backgrounds Shapes Tutorialโs start with โฆ
- SVG circle element
- SVG rect element โฆ shapes yesterday, we add โฆ
- SVG ellipse element functionality today โฆ and for all these, as well as the โฆ
- SVG text element we start allowing โshape numericsโ as being a user definable th
aing
These โshape numericsโ can help the user control (that SVG elementโs) โฆ
- position
- size
- opacity
- font size โฆ (for text elements) on top of that non-numeric control yesterdayโs work gave us, being (that SVG elementโs fill) โฆ
- colour
This is all handled, still, within that โimageโ argument definition, and we allow a decimal (ie. โ.โ) delimiter be the way a user separates their integer values (where an opacity value becomes โ0.โ + [integerValue]).
As an example take a look at the example โฆ
URL |
---|
https://www.rjmprogramming.com.au/inline_svg.php?uctext=hello%0Az267.254&mltext=bonjour&image=PHP/one.jpg%23ellipsepurple267.254.156.89.6,noimage |
Iframe |
The PHPcode changes for inline_svgphpโs liverun principally involved two new PHP functions โฆ
Collect information at a suitable juncture โฆ |
---|
<?php
?> |
Reshape a default SVG element definition depending on the information collected |
<?php
?> |
Integration tasks await!
Previous relevant Emoji Borders and Backgrounds Shapes Tutorial is shown below.
Onto yesterdayโs Emoji Borders and Backgrounds Text Justification Tutorial we add some consideration of SVG shape creations into the mix of the Emoji Borders and Backgrounds work, starting just with the PHP tool, at this stage, and just considering โฆ
โฆ to start off with, and feeding off yesterdayโs โฆ
- width=[designatedPxWidth] and height=[designatedPxHeight] โฆ and/or โฆ
- image=[someImageUrl] (width and height)
โฆ breakdown as to how a user can define a box of interest, as a great โline in the sandโ for us to work around with this new โShapes functionalityโ. Itโs an interfacing job, for tomorrow, getting parents to work with this โimageโ argument based way a user can define these shapes, including a โnoimageโ option that uses an imageโs width and height (to help out with the shape definition) but does not display that image.
Along the way we also mildly rearrangePHP code for inline_svgphpโs liverun so as to allow for more than one user text to be added via justification prefixing methodologies.
Previous relevant Emoji Borders and Backgrounds Text Justification Tutorial is shown below.
Yesterdayโs Emoji Borders and Backgrounds CSS Styling Tutorialโs work involving โฆ
- SVG CSS styling โฆ could be classified as an โaestheticsโ matter, as could todayโs โฆ
- SVG text justification
โฆ work, though there is no CSS involved with todayโs solutions that we have decided on. But we did get great help from โHow to place and center text in an SVG rectangle โ Stack Overflowโ, thanks, getting us to use a lot more โฆ
text-anchor="end"
โฆ SVG text element attributing to neaten our emojis up and for the 2nd character โrโ text justifications below โฆ
- ultext=[SomeText] โฆ top left justification
- uctext=[SomeText] โฆ top center justification
- urtext=[SomeText] โฆ top right justification
- mltext=[SomeText] โฆ middle left justification
- mctext=[SomeText] โฆ middle center justification (our inhouse default โฆ ie. text=[SomeText] is the same)
- mrtext=[SomeText] โฆ middle right justification
- bltext=[SomeText] โฆ bottom left justification
- bctext=[SomeText] โฆ bottom center justification
- brtext=[SomeText] โฆ bottom right justification
โฆ relative to one or both (modes of user defining a box) of โฆ
- width=[designatedPxWidth] and height=[designatedPxHeight] โฆ and/or โฆ
- image=[someImageUrl] (width and height)
Our changedPHP tool inline_svgphpโs live
run needed tweaks in the code parsing arguments โฆ
<?php
$gminus30=-1;
$gtop30=-1;
$eight=8;
$twentyfive=25;
$threedotone=3.1;
$textjust="";
$wtwo=2.0;
$htwo=2.0;
$tn='text';
foreach ($_GET as $name=>$val) {
if (strpos(strtolower('' . $name . '~'), 'css~') !== false) {
if ($svgmiddle == '') {
$svgmiddle="
<style type=\"text/css\" >
<![CDATA[
." . strtolower($name) . " { " . str_replace(';;',';',trim(str_replace('+',' ', urldecode($_GET[$name]))) . ';') . " }
]]>
</style>
";
} else {
$svgmiddle=str_replace("<![CDATA[", "<![CDATA[
." . strtolower($name) . " { " . str_replace(';;',';',trim(str_replace('+',' ', urldecode($_GET[$name]))) . ';') . " } ", $svgmiddle);
}
} else if (strpos(strtolower('' . $name . '~'), 'text~') !== false) {
$tn=$name;
if (strpos(strtolower('~' . $name . '~'), '~text~') !== false) {
$textjust="";
} else if (strtolower(substr($name,0,1)) == 't' || strtolower(substr($name,0,1)) == 'u') {
$htwo=$h;
$eight=0;
$twentyfive=30;
} else if (strtolower(substr($name,0,1)) == 'b' || strtolower(substr($name,0,1)) == 'l') {
$htwo=1;
$gtop30=0;
}
if (strpos(strtolower('' . $name . '~'), 'rtext~') !== false) {
$textjust=' text-anchor="end" ';
$gminus30=(-20 + $w);
}
if (strpos(strtolower('' . $name . '~'), 'ltext~') !== false) {
$wtwo=$w;
$gminus30=20;
$threedotone=0;
}
}
}
foreach ($_POST as $name=>$val) {
if (strpos(strtolower('' . $name . '~'), 'css~') !== false) {
if ($svgmiddle == '') {
$svgmiddle="
<style type=\"text/css\" >
<![CDATA[
." . strtolower($name) . " { " . str_replace(';;',';',trim(str_replace('+',' ', urldecode($_POST[$name]))) . ';') . " }
]]>
</style>
";
} else {
$svgmiddle=str_replace("<![CDATA[", "<![CDATA[
." . strtolower($name) . " { " . str_replace(';;',';',trim(str_replace('+',' ', urldecode($_POST[$name]))) . ';') . " }
", $svgmiddle);
}
} else if (strpos(strtolower('' . $name . '~'), 'text~') !== false) {
$tn=$name;
if (strpos(strtolower('~' . $name . '~'), '~text~') !== false) {
$textjust="";
} else if (strtolower(substr($name,0,1)) == 't' || strtolower(substr($name,0,1)) == 'u') {
$htwo=$h;
$eight=0;
$twentyfive=30;
} else if (strtolower(substr($name,0,1)) == 'b' || strtolower(substr($name,0,1)) == 'l') {
$htwo=1;
$gtop30=0;
}
if (strpos(strtolower('' . $name . '~'), 'rtext~') !== false) {
$textjust=' text-anchor="end" ';
$gminus30=(-20 + $w);
}
if (strpos(strtolower('' . $name . '~'), 'ltext~') !== false) {
$wtwo=$w;
$gminus30=20;
$threedotone=0;
}
}
}
?>
โฆ in order to โflesh outโ our SVG text element creations. Dรฉjร vu (all over again) for attentive readers below.
The inhouse slideshow PHP clonesโ changedassociated external Javascript inhouse_slideshowjs now prompts โฆ
Please enter comma separated HTML decimal entity(s) for your Emoji Border to slideshow. Can use an Emoji Menu entry (eg. control-command-space for macOS or Mac OS X, logo key + . (period) for Windows, control+space for iOS, top left + for Android keyboard). Optionally append &[text|image]css=[CSSstyle] to change styling. Optionally justify some text via &[ul|uc|ur|ml|[mc]|mr|bl|bc|br]text=[someText%0AsecondLine] to change styling. Eg.
&css=opacity:0.9;&textcss=font-size:20px;&ultext=Hello%0AThere
The Image Map Grid changedPHP imagegridmapphpโs live
run now prompts โฆ
Please enter comma separated HTML decimal entity(s) for your Emoji Border to slideshow. Can use an Emoji Menu entry (eg. control-command-space for macOS or Mac OS X, logo key + . (period) for Windows, control+space for iOS, top left + for Android keyboard). Optionally append &[text|image]css=[CSSstyle] to change styling. Optionally justify some text via &[ul|uc|ur|ml|[mc]|mr|bl|bc|br]text=[someText%0AsecondLine] to change styling. Eg.
&iurl=four.jpg&css=opacity:0.9;font-size:20px;&textcss=text-shadow: -2px 2px 3px #ff2d95;&ultext=Hello%0AThere
Day before yesterdayโs (third parent (to our PHP tool) โcab off the rankโ) SVG -> IMG -> CANVAS changedPHP canvas_svgphp live
run now prompts โฆ
Please enter comma separated HTML decimal entity(s) for your Emoji Border to graphics. Can use an Emoji Menu entry (eg. control-command-space for macOS or Mac OS X, logo key + . (period) for Windows, control+space for iOS, top left + for Android keyboard). Optionally append &iurl=[newImageURL] to change base image. Optionally append &[text|image]css=[CSSstyle] to change styling. Optionally justify some text via &[ul|uc|ur|ml|[mc]|mr|bl|bc|br]text=[someText%0AsecondLine] to change styling. Eg.
&iurl=four.jpg&css=opacity:0.9;font-size:20px;&textcss=text-shadow: -2px 2px 3px #ff2d95;&ultext=Hello%0AThere
Previous relevant Emoji Borders and Backgrounds CSS Styling Tutorial is shown below.
It was some time ago now that we said โฆ
โฆ via a new โtextโ argument arranged for the PHP and in readiness for some more aesthetic improvements in the display side of things with our emoji borders and backgrounds
Well, what gives? Eh, wotโs up โguv? Yes, indeed โฆ all we can say is โฆ
We got sidetracted.
โฆ and applying spell checker to get around an expression that amuses us โฆ
We got sidetracked.
So, โbeing โguvโ โฆ eh, wot โฆ today weโre having a posting catch up with all the parents and PHP tool child allowing for some CSS styling to be a possibility with the web applications around the theme of โEmoji Borders and Backgroundsโ, onto yesterdayโs Emoji Borders and Backgrounds in Canvas Tutorial.
And so wotwhatโs the go with styling in SVG โlandโ? Is SVG classy? Itโs not that much different to HTML and CSS, in that โstyleโ elements are allowed, and SVG allows you to define a โclassโ attribute for SVG elements, so thatโs kind of classy โฆ eh, wot, โguv?! Thanks to this great link for the heads up on this.
We decided to allow for ourchanged inline_svgphp PHP toolโs PHP
tool live run to understand all arguments coming in whose name ends in CSS โฆ
<?php
$svgmiddle='';
foreach ($_GET as $name=>$val) {
if (strpos(strtolower('' . $name . '~'), 'css~') !== false) {
if ($svgmiddle == '') {
$svgmiddle="
<style type=\"text/css\" >
<![CDATA[
." . strtolower($name) . " { " . str_replace(';;',';',trim(str_replace('+',' ', urldecode($_GET[$name]))) . ';') . " }
]]>
</style>
";
} else {
$svgmiddle=str_replace("<![CDATA[", "<![CDATA[
." . strtolower($name) . " { " . str_replace(';;',';',trim(str_replace('+',' ', urldecode($_GET[$name]))) . ';') . " } ", $svgmiddle);
}
}
}
foreach ($_POST as $name=>$val) {
if (strpos(strtolower('' . $name . '~'), 'css~') !== false) {
if ($svgmiddle == '') {
$svgmiddle="
<style type=\"text/css\" >
<![CDATA[
." . strtolower($name) . " { " . str_replace(';;',';',trim(str_replace('+',' ', urldecode($_POST[$name]))) . ';') . " }
]]>
</style>
";
} else {
$svgmiddle=str_replace("<![CDATA[", "<![CDATA[
." . strtolower($name) . " { " . str_replace(';;',';',trim(str_replace('+',' ', urldecode($_POST[$name]))) . ';') . " }
", $svgmiddle);
}
}
}
?>
โฆ to add the means by which the SVGโs optional โstyleโ elements be populated, leaving it up to the various parents to inform the users of the possibilities here.
The inhouse slideshow PHP clonesโ changedassociated external Javascript inhouse_slideshowjs now prompts โฆ
Please enter comma separated HTML decimal entity(s) for your Emoji Border to slideshow. Can use an Emoji Menu entry (eg. control-command-space for macOS or Mac OS X, logo key + . (period) for Windows, control+space for iOS, top left + for Android keyboard). Optionally append &[text|image]css=[CSSstyle] to change styling. Eg.
&css=opacity:0.9;&textcss=font-size:20px;
The Image Map Grid changedPHP imagegridmapphpโs live
run now prompts โฆ
Please enter comma separated HTML decimal entity(s) for your Emoji Border to slideshow. Can use an Emoji Menu entry (eg. control-command-space for macOS or Mac OS X, logo key + . (period) for Windows, control+space for iOS, top left + for Android keyboard). Optionally append &[text|image]css=[CSSstyle] to change styling. Eg.
&iurl=four.jpg&css=opacity:0.9;font-size:20px;&textcss=text-shadow: -2px 2px 3px #ff2d95;
Yesterdayโs (third parent (to our PHP tool) โcab off the rankโ) SVG -> IMG -> CANVAS changedPHP canvas_svgphp live
run now prompts โฆ
Please enter comma separated HTML decimal entity(s) for your Emoji Border to graphics. Can use an Emoji Menu entry (eg. control-command-space for macOS or Mac OS X, logo key + . (period) for Windows, control+space for iOS, top left + for Android keyboard). Optionally append &iurl=[newImageURL] to change base image. Optionally append &[text|image]css=[CSSstyle] to change styling. Eg.
&iurl=four.jpg&css=opacity:0.9;font-size:20px;&textcss=text-shadow: -2px 2px 3px #ff2d95;
Previous relevant Emoji Borders and Backgrounds in Canvas Tutorial is shown below.
Extending yesterdayโs Emoji Borders and Backgrounds in Image Map Grid Tutorialโs โEmoji Border and Backgroundโ horizons, today, we take an interest in three associated HTML โgraphicโ elements โฆ
Can we start with SVG+XML data and get to populate CANVAS data via IMG data via data URIs? Well, not everything works, but enough works to have a lot of what youโd want to do โin this neck of the woodsโ be possible.
<?php
var svg = document.querySelector('svg');
var img = document.querySelector('img');
var canvas = document.querySelector('canvas');
// get svg data
var xml = new XMLSerializer().serializeToString(svg);
//alert(xml);
// make it base64
var svg64 = ''; //btoa(xml);
var b64Start = ''; //'data:image/svg+xml;base64,';
<?php
$mb=maybedef('');
$bemb="";
if (strpos($mb, "</svg>") !== false) {
$mb='<svg' . explode('<svg', explode('</svg>', $mb)[0])[1] . '</svg>';
$bemb='data:image/svg+xml;base64,' . base64_encode($mb);
}
if ($bemb == "") {
echo "\n svg64 = btoa(xml); \n";
echo "\n b64Start = 'data:image/svg+xml;base64,'; \n";
}
?>
// prepend a "header"
var image64 = <?php echo maybedef('b64Start + svg64'); ?>;
// set it as the source of the img element
img.onload = function() {
// draw the image onto the canvas
canvas.getContext('2d').drawImage(img, 0, 0);
}
<?php
if ($bemb != "") {
echo "\n img.src = '" . $bemb . "'; \n";
} else {
echo "\n img.src = image64; \n";
}
?>
}
?>
Weโd like to thank html โ Drawing an SVG file on a HTML5 canvas โ Stack Overflow for the idea that we expand on with our โproof of conceptโ canvas_svgphpโs live
run web application (calling ourchanged inline_svg
php PHP toolโs PHP
tool live run).
Previous relevant Emoji Borders and Backgrounds in Image Map Grid Tutorial is shown below.
Further to yesterdayโs Emoji Borders and Backgrounds in Inhouse Slideshow Deployment Tutorial were you around when we presented Image Map Grid Styling Email Share Tutorial?
Well, itโs our โsecond cab off the rankโ regarding a parent idea to oversee our current PHP tool idea for Emoji Borders and Backgrounds.
Anything new? Well, yes, quite a big concept too. With our PHP tool, today, we are allowing it, for a PHP parent (todayโschanged imagegridmapphpโs live
run), to fill in a โฆ
<?php
var tableih='<table id=oneandonly style=\"' + tw + th + 'background:" . $opprefix . "URL(" . backg("' + indu + '") . ");background-repeat:no-repeat;background-size:' + tcover + ';' + tcss + '\"><tbody id=oneandonlytbody style=\"width:100%;' + 'height:100%;\"></tbody></table>';
?>
โฆ background image (to a table element) data URI with mimetype image/svg+xml and base64 encoding via โฆ
<?php
function backg($indef) {
global $prebimg, $bimg, $udirname, $poemoji;
$udirnameprebimg=$udirname . $prebimg;
if (isset($_GET['iurl'])) {
$udirnameprebimg=str_replace('+',' ',urldecode($_GET['iurl']));
} else if (isset($_POST['iurl'])) {
$udirnameprebimg=str_replace('+',' ',urldecode($_POST['iurl']));
}
if (isset($_GET['emoji'])) {
$poemoji='<input type=hidden id=emoji name=emoji value="' . str_replace('+','',urldecode($_GET['emoji'])) . '"></input>';
list($wdt, $hgt) = getimagesize($udirnameprebimg);
if ($wdt > 0 && $hgt > 0) {
//echo $udirname . "1:" . $hgt;
return file_get_contents($udirname . "../inline_svg.php?asbackground=y&imaXge=" . urlencode($udirnameprebimg) . "&width=" . (-20 + $wdt) . "&height=" . (-20 + $hgt) . "&insvg=" . str_replace('+','',urldecode($_GET['emoji']))) . '),URL(' . $indef;
} else {
//echo "2:" . $hgt;
return file_get_contents($udirname . "../inline_svg.php?asbackground=y&image=" . urlencode($udirnameprebimg) . "&insvg=" . str_replace('+','',urldecode($_GET['emoji']))) . '),URL(' . $indef;
}
} else if (isset($_POST['emoji'])) {
$poemoji='<input type=hidden id=emoji name=emoji value="' . str_replace('+','',urldecode($_POST['emoji'])) . '"></input>';
list($wdt, $hgt) = getimagesize($udirnameprebimg);
if ($wdt > 0 && $hgt > 0) {
return file_get_contents($udirname . "../inline_svg.php?asbackground=y&imaXge=" . urlencode($udirnameprebimg) . "&width=" . (-20 + $wdt) . "&height=" . (-20 + $hgt) . "&insvg=" . str_replace('+','',urldecode($_POST['emoji']))) . '),URL(' . $indef;
} else {
return file_get_contents($udirname . "../inline_svg.php?asbackground=y&image=" . urlencode($udirnameprebimg) . "&insvg=" . str_replace('+','',urldecode($_POST['emoji']))) . '),URL(' . $indef;
}
} else {
return $indef;
}
}
?>
Interesting idea, donโt you think?
It meant a division of two โthreadsโ of modus operandi (possible by โoverridingโ the PHP echo function into an inhouse โourechoโ (wrapper style of) function), now, for ourchanged inline_svgphp PHP toolโs PHP
tool live run โฆ
<?php
$asbkg=false;
$whati='image';
if (isset($_GET['asbackground']) || isset($_POST['asbackground'])) {
$asbkg=true;
$whati='youllneverfindthis';
} else {
header('Content-type: image/svg+xml');
}
// In here are echo"ourecho" codeline calls to construct the SVG+XML
function ourecho($inh) {
global $asbkg;
if ($asbkg) {
echo "data:image/svg+xml;base64," . base64_encode('<svg' . explode('<svg', explode('</svg>', $inh)[0])[1] . '</svg>');
} else {
echo $inh;
}
}
?>
And donโt you just love โthe two steptwo thread jiveโ!
Previous relevant Emoji Borders and Backgrounds in Inhouse Slideshow Deployment Tutorial is shown below.
The deployment aspects to yesterdayโs Emoji Borders and Backgrounds in Inhouse Slideshow Tutorial โInhouse Slideshowโ PHP functionality are in our sights today โฆ happy holidays!
โInhouse Slideshowโ functionality can not avoid the serverside PHP (ie. thechanged indexphp PHP clone โoriginalโ and clone) in all its aspects, and so we still need โฆ
- the kind of clunky โmany PHP clonesโ approach we talked about at Inhouse Slideshow Design Exif Korn Shell Deployment Tutorial for PHP serverside deployment (via thechanged job
ksh Korn Shell script parent creator of and โaskerโ of therealchange
ksh file copying Korn Shell deployer command line script) aspects to โInhouse Slideshowsโ (and as you can see with todayโs tutorial animated GIF picture), but, as we introduced with this round of such โฆ but as of yesterday โฆ
- for your more ephemeral โclientside onlyโ tweaks weโve started, today, with inhouse_slideshow
js to use Javascript junction โoverridesโ (of PHP Javascript ones above) are possible as a โsingle external Javascript code fileโ maintenance ongoing possibility for โInhouse Slideshowโ functionality โฆ
// inhouse_slideshow.js
// RJM Programming
// January, 2022
// Help out with ephemeral aspects to Inhouse Slideshow PHPs
function changeto(tvis) {
if (tvis.toLowerCase().indexOf('exif') == 0) {
if (document.URL.indexOf('?') == -1) {
location.href=posturl(document.URL.split('#')[0] + '?exif=y');
} else {
location.href=posturl(document.URL.split('#')[0].replace(/pdf\=/g, 'pdTf=') + '&exif=y');
}
} else if (tvis.toLowerCase().indexOf('pdf') == 0) {
if (document.URL.indexOf('?') == -1) {
location.href=posturl(document.URL.split('#')[0] + '?pdf=y');
} else {
location.href=posturl(document.URL.split('#')[0].replace(/exif\=/g, 'exTif=') + '&pdf=y');
}
} else if (tvis.toLowerCase().indexOf('emoji') == 0) {
//var borderis=prompt('Please enter comma separated HTML decimal entity(s) for your Emoji Border to slideshow. Can use an Emoji Menu entry.', '');
borderblurb='Please enter comma separated HTML decimal entity(s) for your Emoji Border to slideshow. Can use an Emoji Menu entry (eg. control-command-space for macOS or Mac OS X, logo key + . (period) for Windows, control=space for iOS, top left + for Android keyboard). ';
var borderis=prompt(borderblurb, '');
var emojiy='';
if (borderis == null) { borderis=''; } else { borderis=postbb(borderis); }
if (borderis != '') { emojiy='emoji=' + encodeURIComponent(borderis); }
if (emojiy != '') {
if (document.URL.indexOf('?') == -1) {
location.href=posturl(document.URL.split('#')[0] + '?' + emojiy);
} else {
location.href=posturl(document.URL.split('#')[0].replace(/emoji\=/g, 'emojTi=') + '&' + emojiy);
}
}
} else {
if (document.URL.indexOf('exif=') != -1 || document.URL.indexOf('pdf=') != -1) {
location.href=posturl(document.URL.split('#')[0].replace(/exif\=/g, 'exTif=').replace(/pdf\=/g, 'pdTf='));
} else {
location.href=posturl(document.URL.split('#')[0] + '&eHuhxif=y');
}
}
}
function postbb(inp) {
if (inp != '' && inp.replace(/0/g,'').replace(/1/g,'').replace(/2/g,'').replace(/3/g,'').replace(/4/g,'').replace(/5/g,'').replace(/6/g,'').replace(/7/g,'').replace(/8/g,'').replace(/9/g,'').replace(/\&/g,'').replace(/\#/g,'').replace(/\;/g,'').replace(/\,/g,'') != '') {
return inp;
} else if (inp != '' && inp.replace(/0/g,'').replace(/1/g,'').replace(/2/g,'').replace(/3/g,'').replace(/4/g,'').replace(/5/g,'').replace(/6/g,'').replace(/7/g,'').replace(/8/g,'').replace(/9/g,'').replace(/\,/g,'') == '') {
if (eval('' + inp.split(',').length) >= 4) {
eval('inp=String.fromCodePoint(' + inp + ')');
}
return inp;
} else if (inp != '' && inp.replace(/0/g,'').replace(/1/g,'').replace(/2/g,'').replace(/3/g,'').replace(/4/g,'').replace(/5/g,'').replace(/6/g,'').replace(/7/g,'').replace(/8/g,'').replace(/9/g,'').replace(/\&/g,'').replace(/\#/g,'').replace(/\;/g,'') == '') {
var outp=inp.replace(/\&\#/g,',').replace(/\;/g,',');
outp=outp.trim(',');
outp=outp.replace(/\,\,\,\,/g,',');
outp=outp.replace(/\,\,\,/g,',');
outp=outp.replace(/\,\,/g,',');
outp=outp.trim(',');
outp=('~' + outp + '~').replace('~,','').replace(',~','').replace(/\~/g,'');
if (eval('' + outp.split(',').length) >= 4) {
eval('outp=String.fromCodePoint(' + outp + ')');
}
return outp;
}
//alert(String.fromHtmlEntities(inp));
//alert(inp.toHtmlEntities());
return inp;
}
function posturl(inpu) {
return inpu;
}
โฆ including that one change to Javascript prompt popup window wording as an example of an ephemeral โclientside onlyโ tweak โฆ becomes a possibility (which is optional โฆ ie. the PHP wonโt fail if such an external Javascript does not exist, as those of you actively trying our guinea pig Inhouse Slideshow yesterday might attest to?!)
Previous relevant Emoji Borders and Backgrounds in Inhouse Slideshow Tutorial is shown below.
Continuing on from yesterdayโs Emoji Borders and Backgrounds via Emoji Menu Tutorial and harkening back to Emoji Borders and Backgrounds Image Text Parent Tutorialโs โฆ
โฆ the functionalities that would be โcoolโ at the HTML/Javascript/CSS parent side, and then work out how to implement similar functionality, as possible, in SVG, and if possible, we should be able to pass arguments over to the โPHP toolโ to eventually code it to be standalone to help other โparenting arrangementsโ.
โฆ todayโs โthemeโ concerns the first of those other โparenting arrangementsโ mentioned above, our PHP for Inhouse Slideshow presentation display options โฆ
โฆ the new โEmoji Border Slideshowโ display option above calling into play our inline_svgphp PHP toolโs live
run (โAre we there yet, as a tool, I mean โฆ Mum โฆ Dad โฆ anyone?โ) web application.
And in so doing, to use an Emoji Menu methodology of selecting your emoji border decoration is โright up your street, Inhouse Slideshow supervisorโ.
You will find, examining thechanged PHPcode representative
โfirst cab off the rankโ and โguinea pigโ live run that we introduce a non-existant external Javascript call โฆ
<script type='text/javascript' src='/inhouse_slideshow.js' defer></script>
โฆ into the mix. Why? Well, perhaps, first off, you should read some history of this โInhouse Slideshowโ project over time at Inhouse Slideshow Temporary Unzip Tutorial and then see that this โexternal Javascript larkโ could be better for a way to โfuture proofโ the venture, with some improvements being changeable through one (into your chosen Document Root folder, wherever that may be (that is what the leading โ/โ infers)) external Javascript codefile rather than a myriad number of identical PHP codefiles.
Previous relevant Emoji Borders and Backgrounds via Emoji Menu Tutorial is shown below.
On this macOS MacBook Air weโre used to โฆ
control-command-space
โฆ bringing up an Emoji Menu from which an emoji can be selected and placed wherever the cursor had been placed before that menu display. That could be โฆ
- on an address bar where the cursor is placed
- in a Javascript prompt window that is focussed
โฆ both scenarios (amongst many others, no doubt) of which we will be interested with our current Emoji Borders and Background web application project. Todayโs work develops our PHP tool ahead of its supervisory web application, and so we are interested in the first scenario above, as far as testing it goes with ourchanged underlying inline_svgphp PHP tool live
run web application.
The argument โtextโ is already catered for from yesterday but the nature of the data this $_GET[โtextโ] might contain had not catered for โฆ
- unicode data (via Emoji Menus) โฆ but rather had catered for โฆ
- Javascript call of String.fromCodePoint([comma separated list of HTML Decimal Entity(s)]);
โฆ only, as of yesterdayโs Emoji Borders and Backgrounds Image Text PHP SVG Tutorial. As you would probably concur, yesterdayโs setup was quite user unfriendly, as so many of us now are used to those Emoji Menus being used to fill in your emoji data requirements.
The main gist of the PHP code changes goes โฆ
<?php
$innards='';
$preinnards='';
function ingp($m) { // thanks to https://pretagteam.com/question/how-do-i-convert-unicode-special-characters-to-html-entities
global $innards, $preinnards;
if ($innards != '') {
$entity = preg_replace_callback('/[\x{80}-\x{10FFFF}]/u', function ($m) {
$char = current($m);
$utf = iconv('UTF-8', 'UCS-4', $char);
return sprintf("&#x%s;", ltrim(strtoupper(bin2hex($utf)), "0"));
}, $innards);
$preinnards=htmlentities($entity);
$innards='';
}
}
// And then later we change ...
if (isset($_GET['insvg'])) {
$innards=str_replace('+','',urldecode($_GET['insvg']));
if (trim(str_replace(',','',str_replace('0','',str_replace('1','',str_replace('2','',str_replace('3','',str_replace('4','',str_replace('5','',str_replace('6','',str_replace('7','',str_replace('8','',str_replace('9','',$innards)))))))))))) != '') {
ingp($innards);
}
if ($preinnards == '') {
$preinnards='&#' . str_replace(',',';&#',$innards) . ';';
}
// rest of if block code uses $preinnards as SVG text innerHTML ... but UTF-16 Surrogate pair scenarios can fail
}
?>
Previous relevant Emoji Borders and Backgrounds Image Text PHP SVG Tutorial is shown below.
To add to yesterdayโs Emoji Borders and Backgrounds Image Text Parent Tutorial today it is โPHP toolโ work catching up so as to say โฆ
- emoji border โฆ now with content control via comma separated list of emoji HTML decimal Entity(s) โฆ argumented to PHP tool
- emoji background โฆ now with content control via comma separated list of emoji HTML decimal Entity(s) โฆ argumented to PHP tool
- centralized text (in foreground) โฆ now with wording control via HTML span contenteditable=true elements โฆ
not yetargumented to PHP tool
<?php
if (isset($_GET['text'])) {
$txt=str_replace("\n","<br>", str_replace(' ',' ',str_replace('+', ' ', urldecode($_GET['text']))));
$minus30=($w / 2.0) - strlen(explode('<br>', $txt)[0]) * 3.1;
$top30=($h / 2.0) + 25 - (sizeof(explode('<br>', $txt)) * 8);
$lines=explode('<br>', $txt);
for ($il=0; $il<sizeof($lines); $il++) {
$textcontent.='<text x="' . $minus30 . '" y="' . $top30 . '">' . $lines[$il] . '</text>';
$top30+=15;
}
} else if (isset($_POST['text'])) {
$txt=str_replace("\n","<br>", str_replace(' ',' ',str_replace('+', ' ', urldecode($_POST['text']))));
$minus30=($w / 2.0) - strlen(explode('<br>', $txt)[0]) * 3.1;
$top30=($h / 2.0) + 25 - (sizeof(explode('<br>', $txt)) * 8);
$lines=explode('<br>', $txt);
for ($il=0; $il<sizeof($lines); $il++) {
$textcontent.='<text x="' . $minus30 . '" y="' . $top30 . '">' . $lines[$il] . '</text>';
$top30+=15;
}
}
?>
- centralized image (in foreground) โฆ including some width and height control โฆ argumented to PHP tool
โฆ via a new โtextโ argument arranged for the PHP and in readiness for some more aesthetic improvements in the display side of things with our emoji borders and backgrounds changedunderlying inline_svgphp PHP tool live
run web application (or in iframe).
Previous relevant Emoji Borders and Backgrounds Image Text Parent Tutorial is shown below.
Todayโs work continues on from yesterdayโs Emoji Borders and Backgrounds for Image Tutorial combining both โฆ
- inline_svg
php underlying PHP live
run (or in iframe) โฆ modelled under โฆ
- todayโschanged emoji_border_background
html HTML Parent
โฆ partnership during testing. Our final aim is to make the โunderlying PHPโ a proper standalone tool, but โthatโs a ways offโ, as they say. Why this extra level of complication? Itโs easier to โฆ
- see
- test
- debug (via web browser web inspectors)
โฆ the functionalities that would be โcoolโ at the HTML/Javascript/CSS parent side, and then work out how to implement similar functionality, as possible, in SVG, and if possible, we should be able to pass arguments over to the โPHP toolโ to eventually code it to be standalone to help other โparenting arrangementsโ.
And so, today, we โget functionalโ the combination of parental control through to PHP SVG child display โฆ
Optionally enter an image URL ( as needs be, suffix by &width=[preferredWidth]&height=[preferredHeight] and/or &background=y ) and/or # prefixed comma separated list of emoji HTML decimal Entity(s) ( eg. #127462,127465 ) ? Cancel if it is wording you want to change to the left there.
- emoji border โฆ now with content control via comma separated list of emoji HTML decimal Entity(s) โฆ argumented to PHP tool
- emoji background โฆ now with content control via comma separated list of emoji HTML decimal Entity(s) โฆ argumented to PHP tool
- centralized text (in foreground) โฆ now with wording control via HTML span contenteditable=true elements โฆ not yet argumented to PHP tool
- centralized image (in foreground) โฆ including some width and height control โฆ argumented to PHP tool
function ask(sois) {
var huhi=prompt('Optionally enter an image URL ( as needs be, suffix by &width=[preferredWidth]&height=[preferredHeight] and/or &background=y ) and/or # prefixed comma separated list of emoji HTML decimal Entity(s) ( eg. #127462,127465 ) ? Cancel if it is wording you want to change to the left there.','');
if (huhi == null) { huhi=''; }
if (huhi.trim() != '') {
if (document.URL.indexOf('rjmprogramming.com.au') == -1 && sois.title.indexOf('rjmprogramming.com.au') != -1) {
sois.title=document.URL.substring(0,8) + document.URL.substring(8).split('/')[0] + sois.title.split('rjmprogramming.com.au')[1];
}
if (huhi.indexOf('#') != -1) {
var huhis=huhi.split('#')[1];
for (var ihuhis=0; ihuhis<huhis.length; ihuhis++) {
if (eval('' + ihuhis) < eval('' + huhis.length)) {
if (huhis.substring(ihuhis).substring(0,1).replace('0','').replace('1','').replace('2','').replace('3','').replace('4','').replace('5','').replace('6','').replace('7','').replace('8','').replace('9','').replace(',','') != '') {
huhi=huhi.replace('#' + huhis.split(huhis.substring(ihuhis).substring(0,1))[0], '');
huhis=huhis.split(huhis.substring(ihuhis).substring(0,1))[0];
}
}
}
if (huhis == '') {
if (sois.title.indexOf('?insvg=') != -1) {
sois.title=sois.title.replace('?insvg=' + sois.title.split('?insvg=')[1].split('&')[0].split('#')[0],'');
} else if (sois.title.indexOf('&insvg=') != -1) {
sois.title=sois.title.replace('&insvg=' + sois.title.split('&insvg=')[1].split('&')[0].split('#')[0],'');
}
} else if (sois.title.indexOf('?insvg=') != -1) {
sois.title=sois.title.replace('?insvg=' + sois.title.split('?insvg=')[1].split('&')[0].split('#')[0],'?insvg=' + encodeURIComponent(huhis));
} else if (sois.title.indexOf('&insvg=') != -1) {
sois.title=sois.title.replace('&insvg=' + sois.title.split('&insvg=')[1].split('&')[0].split('#')[0],'&insvg=' + encodeURIComponent(huhis));
} else if (sois.title.indexOf('?') != -1) {
sois.title=sois.title.replace('?','?insvg=' + encodeURIComponent(huhis) + '&');
} else {
sois.title=sois.title.split('#')[0] + '?insvg=' + encodeURIComponent(huhis);
}
}
if (huhi.split('&')[0].split('#')[0].trim() != '') {
if (sois.title.indexOf('?image=') != -1) {
sois.title=sois.title.replace('?image=' + sois.title.split('?image=')[1].split('&')[0].split('#')[0],'');
} else if (sois.title.indexOf('&image=') != -1) {
sois.title=sois.title.replace('&image=' + sois.title.split('&image=')[1].split('&')[0].split('#')[0],'');
}
sois.title+='&image=' + encodeURIComponent(huhi.split('&')[0]) + huhi.replace(huhi.split('&')[0],'');
} else if (sois.title.indexOf('?image=') != -1) {
sois.title=sois.title.replace('?image=' + sois.title.split('?image=')[1].split('&')[0].split('#')[0],'');
} else if (sois.title.indexOf('&image=') != -1) {
sois.title=sois.title.replace('&image=' + sois.title.split('&image=')[1].split('&')[0].split('#')[0],'');
}
document.getElementById(sois.id.replace('span','if')).src=sois.title; //+='&image=' + encodeURIComponent(huhi.split('&')[0]) + huhi.replace(huhi.split('&')[0],'');
}
}
function snapshot(sio) {
lastih=sio.innerHTML;
lastio=-1;
for (var iuh=0; iuh<cds.length; iuh++) {
if (lastih == cds[iuh]) { lastio=iuh; } else if (sio.innerHTML.indexOf(' of ') != -1) { if (lastih.split(' of ')[0] == cds[iuh].split(' of ')[0]) { lastio=iuh; } }
}
}
function newwords(sio) {
if (lastih != sio.innerHTML && lastio >= 0) {
cds[lastio]=sio.innerHTML.replace(/\ \;/g,' ').replace(/\<br\>/g,String.fromCharCode(10));
var documentURL=document.URL.split('#')[0].split('?arr' + lastio + '=')[0].split('&arr' + lastio + '=')[0];
location.href=(documentURL + '&arr' + lastio + '=' + encodeURIComponent(cds[lastio])).replace('.html&','.html?').replace('.htm&','.htm?'); // fancystuff();
}
}
Previous relevant Emoji Borders and Backgrounds Context Tutorial is shown below.
Itโs all fine and good creating the Emoji Borders and Backgrounds of yesterdayโs Emoji Borders and Backgrounds Primer Tutorial, but itโs the context of their use that we are starting to take an interest in with todayโs โฆ
- take yesterdayโs table as a starting bit to our โฆ
- โmaking use ofโ โproof of conceptโ emoji_border_background
html live
run link for you to contextualize and make use of those tableโs iframe contents from yesterday โฆ
โฆ as we figure out, perhaps, some better โtool like genericsโ here. Weโll see (we hope)!
But, so far, how would we assess the approach, here? Well, what we had to do today reminded us a lot of what we do here, often, at this blog, when we talk about โoverlayโ webpage design approaches. CSS position:absolute and opacity and Javascript [element].getBoundingClientRect() all made guest appearances!
Previous relevant Emoji Borders and Backgrounds Primer Tutorial is shown below.
Time for a new project into the new year. Itโs an โold chestnutโ project, for us. Being able to handle โฆ
- borders made up of emoji images (in the form of โimage/svg+xmlโ mimetype data)
- backgrounds made up of emoji images (in the form of โimage/svg+xmlโ mimetype data)
โฆ via โproof of conceptโ (at least for our โPrimerโ tutorial start) inline_svgphpโs single
violin emoji or โฆ
Description | Iframe |
---|---|
Line of Doves of Peace Emojis | |
Border of Train Emojis | |
Background Flag of Andorra Emojis |
Cute, huh?!
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.
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.