Skip to content

Instantly share code, notes, and snippets.

@nitaku
Last active August 29, 2015 14:02
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save nitaku/dc69a4c83ffccca34d9f to your computer and use it in GitHub Desktop.
Save nitaku/dc69a4c83ffccca34d9f to your computer and use it in GitHub Desktop.
Base64 data URI image converter

Drop an image file to compute its data URI representation in Base64.

The conversion is computed client-side using the HTML5 File API (tutorial), so the image is never sent through the internet. It should therefore be very fast and secure!

body {
background: #393d48;
}
#drop_zone {
position: absolute;
left: 0px;
top: 0px;
width: 480px;
height: 500px;
background-repeat: no-repeat;
background-position: 50% 50%;
}
textarea {
position: absolute;
left: 480px;
top: 0px;
width: 480px;
height: 500px;
}
<!DOCTYPE html>
<html>
<head>
<meta name="description" content="Base64 data URI image converter" />
<meta charset="utf-8">
<title>Base64 data URI image converter</title>
<link rel="stylesheet" href="index.css">
</head>
<body>
<div id="drop_zone" style="background-image: url()"/>
<textarea id="output"></textarea>
<script>
function handleFileSelect(evt) {
evt.stopPropagation();
evt.preventDefault();
var file = evt.dataTransfer.files[0]; // File object.
// file must be an image
if (!file.type.match('image.*'))
return;
var reader = new FileReader();
// Closure to capture the file information.
reader.onload = (function(theFile) {
return function(e) {
var data = e.target.result;
document.getElementById('drop_zone').setAttribute('style','background-image: url('+data+');');
document.getElementById('output').innerHTML = data;
};
})(file);
// Read in the image file as a data URL.
reader.readAsDataURL(file);
}
function handleDragOver(evt) {
evt.stopPropagation();
evt.preventDefault();
evt.dataTransfer.dropEffect = 'copy'; // Explicitly show this is a copy.
}
// Setup the dnd listeners.
var dropZone = document.getElementById('drop_zone');
dropZone.addEventListener('dragover', handleDragOver, false);
dropZone.addEventListener('drop', handleFileSelect, false);
</script>
</body>
</html>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment