Skip to content

Commit

Permalink
Added demos used in presso at RootsConf 2011
Browse files Browse the repository at this point in the history
  • Loading branch information
trygve-lie committed May 26, 2011
1 parent 1fc7043 commit 5d347b5
Show file tree
Hide file tree
Showing 7 changed files with 340 additions and 0 deletions.
53 changes: 53 additions & 0 deletions src/server.js
@@ -0,0 +1,53 @@
var http = require('http');
var url = require('url');
var path = require('path');
var fs = require('fs');
var sys = require('sys');
var io = require('socket.io');


// Simplest HTTP server eva!
server = http.createServer( function ( request, response ){

var uri = url.parse(request.url).pathname;
var filepath = "www" + uri;
if (filepath.substring(filepath.length - 1) === '/') {
filepath += 'index.html';
}

path.exists(filepath, function ( ex ) {

if (!ex) {
response.writeHead(404, {'Content-Type': 'text/html'});
response.write("404 - File not found: " + uri);
response.end();
return;
}

fs.readFile(filepath, "binary", function ( error, filecontent ) {

if (error) {
response.writeHead(500, {'Content-Type': 'text/html'});
response.write("500 - Could not read " + filepath + " from file system!");
response.end();
return;
}

response.writeHead(200, {'Content-Type': 'text/html'});
response.write(filecontent, "binary");
response.end();
});

});

});
server.listen(8080);


// Even simpler websocket server
var socket = io.listen(server);
socket.on('connection', function ( client ) {
client.on('message', function ( message ) {
client.broadcast( message );
});
});
39 changes: 39 additions & 0 deletions src/www/chat/index.html
@@ -0,0 +1,39 @@
<!document html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, maximum-scale=1.0">
<title>Simple Chat</title>
<style>
div {margin-top: 100px; margin-left: auto; margin-right: auto; width: 50%;}
textarea {padding: 5px 5px 5px 5px;}
</style>
<script src="/socket.io/socket.io.js"></script>
<script>
var socket = new io.Socket(null, {port: 8080, rememberTransport: true});
socket.connect();

socket.on('message', function( obj ){

if ( typeof obj !== 'object' ) {
var dataObj = JSON.parse(obj);
if ( dataObj.demo.type === "chat" ) {
var recEl = document.getElementById("rec");
recEl.value = dataObj.demo.message;
}
}
});

var send = function (ev) {
var chat = {"demo" : {
"type" : "chat",
"message" : ev.value
}};
socket.send(JSON.stringify(chat));
};
</script>
</head>
<body>
<textarea id="rec" rows="20" cols="80" onkeyup="send(this);"></textarea>
</body>
</html>
48 changes: 48 additions & 0 deletions src/www/index.html
@@ -0,0 +1,48 @@
<!document html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, maximum-scale=1.0">
<title>"HTML5" Clients Interacting Demos</title>
</head>
<body>
<h1>"HTML5" Clients Interacting Demos</h1>
<p>
These are small demos on two or more clients interacting with each other. Many of the demos has a recorder
and a screen. The recorder are intended to be used as a "remote" to control whats going on on the "screen".
When using a demo with both a recorder and a screen, open the recorder in the client (device) which shall be
the controlling part and the screen in the client which shall be the controlled part.
</p>

<hr>

<h2>Simple Chat</h2>
<p>
<a href="chat/">A simple chat</a> example. The example use WebSockets to transfer plain text between two or
more clients.
</p>

<hr>

<h2>Instant Camera</h2>
<p>
A demo using the Device API for accessing the camera on a device and instantly projecting snapshot images from
the recording client to a screen client. The snapshot images are transferred between the clients by a
WebSocket connection.
</p>
<p>
<a href="instant_camera/recorder.html">Open recorder</a> - <a href="instant_camera/screen.html">Open screen</a>
</p>

<hr>

<h2>Remote Rotation</h2>
<p>
A demo using the DeviceOrientation API to capture the rotation of the recording client and remotely rotate a
a image in a screen client. Communication between the clients are done with WebSockets.
</p>
<p>
<a href="remote_rotation/recorder.html">Open recorder</a> - <a href="remote_rotation/screen.html">Open screen</a>
</p>
</body>
</html>
64 changes: 64 additions & 0 deletions src/www/instant_camera/recorder.html
@@ -0,0 +1,64 @@
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, maximum-scale=1.0">
<style>
body {width: 100%;}
canvas {display: none;}
</style>
<title>Instant Camera - Recorder</title>
<script src="/socket.io/socket.io.js"> </script>
<script>

var video, canvas, msg;

var load = function () {

video = document.getElementById('video');
canvas = document.getElementById('canvas');
msg = document.getElementById('error');

var socket = new io.Socket(null, {port: 8080, rememberTransport: true});
socket.connect();

if( navigator.getUserMedia ) {

video.onclick = function () {
var context = canvas.getContext("2d");
context.drawImage(video, 0, 0, 240, 320);

var image = {"demo" : {
"type" : "device",
"image" : canvas.toDataURL("image/png")
}};
var imageObj = JSON.stringify(image);

socket.send(imageObj);
};

var success = function ( stream ) {
video.src = stream;
};

var error = function ( err ) {
msg.innerHTML = "Error: " + err.code;
};

navigator.getUserMedia('video', success, error);

} else {
msg.innerHTML = "Native web camera not supported :(";
}

};

window.addEventListener('DOMContentLoaded', load, false);
</script>
</head>
<body>
<video id="video" width="240" height="320" autoplay> </video>
<p id="error">Click on the video to send a snapshot to the remote screen</p>
<canvas id="canvas" width="240" height="320"> </canvas>
</body>
</html>
43 changes: 43 additions & 0 deletions src/www/instant_camera/screen.html
@@ -0,0 +1,43 @@
<!document html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, maximum-scale=1.0">
<title>Instant Camera - Screen</title>
<style>
img { float: left; margin-right: 5px; margin-bottom: 5px; }
</style>
<script src="/socket.io/socket.io.js"> </script>
<script>
var socket = new io.Socket(null, {port: 8080, rememberTransport: true});
socket.connect();

var el;

var load = function (){
el = document.getElementById('container');
};

socket.on('message', function( obj ){

if ( typeof obj !== 'object' ) {

var dataObj = JSON.parse(obj);

if ( dataObj.demo.type === "device" ) {
var img = document.createElement('img');
img.src = dataObj.demo.image;
el.appendChild(img);
}

}

});

window.addEventListener('DOMContentLoaded', load, false);
</script>
</head>
<body>
<div id="container"> </div>
</body>
</html>
38 changes: 38 additions & 0 deletions src/www/remote_rotation/recorder.html
@@ -0,0 +1,38 @@
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, maximum-scale=1.0">
<title>Remote Rotation - Recorder</title>
<script src="/socket.io/socket.io.js"> </script>
<script>
var socket = new io.Socket(null, {port: 8080, rememberTransport: true});
socket.connect();

var el;

var load = function (ev) {
el = document.getElementById('status');
};

var update = function (ev) {
var orientation = {"demo" : {
"type" : "orientation",
"alpha" : ev.alpha,
"beta" : ev.beta,
"gamma" : ev.gamma
}};
el.innerHTML = "Alpha: " + ev.alpha + " Beta: " + ev.beta + " Gamma: " + ev.gamma;
socket.send(JSON.stringify(orientation));
};

window.addEventListener('DOMContentLoaded', load, false);
window.addEventListener('deviceorientation', update, true);
</script>
</head>
<body>
<h1>Remote Rotation</h1>
<p>Rotate the device to control the image on the remote screen</p>
<div id="status"> </div>
</body>
</html>
55 changes: 55 additions & 0 deletions src/www/remote_rotation/screen.html
@@ -0,0 +1,55 @@
<!document html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, maximum-scale=1.0">
<title>Orentation - Screen</title>
<style>
#container {
width: 400px;
height: 400px;
margin-top: 50px;
margin-left: auto;
margin-right: auto;
}

#img {
position: relative;
left: 72px;
top: 72px;
width: 256px;
height: 256px;
}
</style>
<script src="/socket.io/socket.io.js"> </script>
<script>
var socket = new io.Socket(null, {port: 8080, rememberTransport: true});
socket.connect();

var el;

var load = function (){
el = document.getElementById('img');
};

socket.on('message', function( obj ){

if ( typeof obj !== 'object' ) {
var dataObj = JSON.parse(obj);
if (dataObj.demo.type === "orientation") {
el.style = "-moz-transform: rotate(" + dataObj.demo.alpha + "deg); -ms-transform: rotate(" + dataObj.demo.alpha + "deg); -o-transform: rotate(" + dataObj.demo.alpha + "deg); transform: rotate(" + dataObj.demo.alpha + "deg);"
}
}

});

window.addEventListener('DOMContentLoaded', load, false);
</script>
</head>
<body>
<div id="container">
<img src=""
id="img">
</div>
</body>
</html>

0 comments on commit 5d347b5

Please sign in to comment.