<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta content="stuff, to, help, search, engines, not" name="keywords">
<meta content="What this page is about." name="description">
<meta content="Display Webcam Stream" name="title">
<title>Display Webcam Stream - Thanks to https://www.kirupa.com/html5/accessing_your_webcam_in_html5.htm and https://software.intel.com/en-us/html5/hub/blogs/using-the-getusermedia-api-with-the-html5-video-and-canvas-elements and https://developer.mozilla.org/en-US/docs/Web/API/Canvas_API/Tutorial/Pixel_manipulation_with_canvas</title>

<style>
#container {
margin: 0px auto;
width: 500px;
height: 375px;
border: 10px #333 solid;
}
#videoElement {
width: 500px;
height: 375px;
background-color: #666;
}
video {
position:absolute;
visibility:hidden;
}
</style>
</head>

<body style='background-color:#f0f0f0;'>
<h1>Display Webcam Stream<h1>
<h3>Thanks to <a target=_blank title='https://www.kirupa.com/html5/accessing_your_webcam_in_html5.htm' href='https://www.kirupa.com/html5/accessing_your_webcam_in_html5.htm'>www.kirupa.com</a> and <a target=_blank title='https://software.intel.com/en-us/html5/hub/blogs/using-the-getusermedia-api-with-the-html5-video-and-canvas-elements' href='https://software.intel.com/en-us/html5/hub/blogs/using-the-getusermedia-api-with-the-html5-video-and-canvas-elements'>software.intel.com</a> and <a target=_blank href='https://developer.mozilla.org/en-US/docs/Web/API/Canvas_API/Tutorial/Pixel_manipulation_with_canvas' title='https://developer.mozilla.org/en-US/docs/Web/API/Canvas_API/Tutorial/Pixel_manipulation_with_canvas'>developer.mozilla.org</a> - RJM Programming - April, 2017</h3>
<div id="container">
<video autoplay='true' id='videoElement'></video>
<table><tr><td><canvas id='canvasElement'></canvas></td><td><canvas id='zoom' width=200 height=200></canvas></tr></table>
<button id='grey'>Toggle Greyness</button> <button id='invert'>Toggle Colour Inversion</button> Enable image smoothing: <input type='checkbox' id='smoothbtn'></input> <div id='colour'>Canvas Colour</div><br>
<!--span><button id='email' title='Have ready a Copy of your Webcam via relevant Right Click or Two Finger Gesture'>Email</button> <input title='Have ready a Copy of your Webcam via relevant Right Click or Two Finger Gesture' type='text' id='emailee' value=''></input></span-->
</div>

<br><br><br><br><br><br><script>

var xx=-1, yy=-1, ww=1, hh=1;

var isStreaming = false,
v = document.getElementById('videoElement'),
c = document.getElementById('canvasElement'),
grey = document.getElementById('grey');
invert = document.getElementById('invert');
con = c.getContext('2d');
w = 600,
h = 420,
invertit = false,
greyscale = false;

v.addEventListener('canplay', function(e) {
if (!isStreaming) {
// videoWidth isn't always set correctly in all browsers
if (v.videoWidth > 0) h = v.videoHeight / (v.videoWidth / w);
c.setAttribute('width', w);
c.setAttribute('height', h);
// Reverse the canvas image
con.translate(w, 0);
con.scale(-1, 1);
isStreaming = true;
}
}, false);

v.addEventListener('play', function() {
// Every 33 milliseconds copy the video image to the canvas
setInterval(function() {
if (v.paused || v.ended) return;
con.fillRect(0, 0, w, h);
con.drawImage(v, 0, 0, w, h);
pixelValue();
if (greyscale) goingGrey();
if (invertit) invert();
}, 33);
}, false);

grey.addEventListener('click', function() { greyscale = !greyscale; }, false);
invert.addEventListener('click', function() { invertit = !invertit; }, false);

var goingGrey = function() {
var imageData = con.getImageData(0, 0, w, h);
var data = imageData.data;
for (var i = 0; i < data.length; i += 4) {
var bright = 0.34 * data[i] + 0.5 * data[i + 1] + 0.16 * data[i + 2];
data[i] = bright;
data[i + 1] = bright;
data[i + 2] = bright;
}
con.putImageData(imageData, 0, 0);
}

var invert = function() {
var imageData = con.getImageData(0, 0, w, h);
var data = imageData.data;
for (var i = 0; i < data.length; i += 4) {
data[i] = 255 - data[i]; // red
data[i + 1] = 255 - data[i + 1]; // green
data[i + 2] = 255 - data[i + 2]; // blue
}
con.putImageData(imageData, 0, 0);
};

var pixelValue = function() {
if (xx >= 0 && yy >= 0) {
//document.title=xx + ' AND ' + yy;
var xpixel = con.getImageData(xx, yy, ww, hh);
var xdata = xpixel.data;
var xrgba = 'rgba(' + xdata[0] + ', ' + xdata[1] +
', ' + xdata[2] + ', ' + (xdata[3] / 255) + ')';
//document.title=xrgba + ' ' + xx + ' AND ' + yy;
colour.style.background = xrgba;
colour.innerHTML = 'Canvas Colour ' + xrgba;
}
}


var colour = document.getElementById('colour');
function pick(event) {
var x = event.layerX;
var y = event.layerY;
xx=x;
yy=y;
//document.title=x + ' and ' + y;
var pixel = con.getImageData(x, y, 1, 1);
var data = pixel.data;
var rgba = 'rgba(' + data[0] + ', ' + data[1] +
', ' + data[2] + ', ' + (data[3] / 255) + ')';
colour.style.background = rgba;
colour.textContent = 'Canvas Colour ' + rgba;
}
//c.addEventListener('mousemove', pick);
var zoomctx = document.getElementById('zoom').getContext('2d');

var smoothbtn = document.getElementById('smoothbtn');
smoothbtn.addEventListener('onchange', function() { toggleSmoothing(); }, false);

var toggleSmoothing = function(event) {
zoomctx.imageSmoothingEnabled = this.checked;
zoomctx.mozImageSmoothingEnabled = this.checked;
zoomctx.webkitImageSmoothingEnabled = this.checked;
zoomctx.msImageSmoothingEnabled = this.checked;
};
smoothbtn.addEventListener('change', toggleSmoothing);

var zoom = function(event) {
var x = event.layerX;
var y = event.layerY;
xx=x;
yy=y;
zoomctx.drawImage(c,
Math.abs(x - 5),
Math.abs(y - 5),
10, 10,
0, 0,
200, 200);
};

c.addEventListener('mousemove', zoom);

var video = document.querySelector("#videoElement");

navigator.getUserMedia = navigator.getUserMedia || navigator.webkitGetUserMedia || navigator.mozGetUserMedia || navigator.msGetUserMedia || navigator.oGetUserMedia;

setTimeout(invertclick,1000);

if (navigator.getUserMedia) {
navigator.getUserMedia({video: true}, handleVideo, videoError);
}

function invertclick() {
if (!invertit) {
document.getElementById('invert').click();
setTimeout(invertclick, 1500);
} else {
document.getElementById('invert').click();
}
}

function handleVideo(stream) {
video.src = window.URL.createObjectURL(stream);
}

function videoError(e) {
// do something
}
</script>
</body>
</html>