I'm currently working on a project that involves sending WebGL frames/screenshots to a server for saving to the hard drive and later merging them into a video file. I came across this helpful resource: Exporting video from WebGL
Without delving too much into WebGL specifics, my main goal is to send the content of two client-side JavaScript variables to a localhost node.js server. These variables are:
var frame = frame + 1; //frame counter
var dataUrl = renderer.domElement.toDataURL("image/png"); //encoded screenshot/frame
The receiving server-side code has been provided by Joe Turner (running in node.js). So my question is, how can I send the above variables' content to this node.js script?
var http = require('http');
var querystring = require('querystring');
var fs = require('fs');
// Override to prevent decoding spaces, which may affect base64 encoding
querystring.unescape = function(s, decodeSpaces) {
return s;
};
// Function to pad numbers according to export format
function pad(num) {
var s = "000" + num;
return s.substr(s.length-4);
}
http.createServer(function (request, response) {
request.content = '';
request.addListener("data", function(data) {
request.content += data;
});
request.addListener("end", function() {
if (request.content.trim()) {
request.content = querystring.parse(request.content);
var data = unescape(request.content['data']);
var frame = request.content['frame'];
// Remove data:image/png;base64,
data = data.substr(data.indexOf(',') + 1);
var buffer = new Buffer(data, 'base64');
fs.writeFile('screen-' + pad(frame) + '.png', buffer.toString('binary'), 'binary');
}
});
response.writeHead(200, {
'Content-Type': 'text/plain',
'Access-Control-Allow-Origin': '*',
'Access-Control-Allow-Headers': 'X-Requested-With'
});
response.end();
}).listen(8080, "127.0.0.1");
Could implementing something like this work?
...
...
//WebGL related code
...
...
var frame = frame + 1;
var dataUrl = renderer.domElement.toDataURL("image/png");
$.ajax({
url: "http://127.0.0.1:8080",
type: "POST",
data: {"data": dataUrl, "frame": frame}
});
...
...
As an example, you can check out this experiment: Three.js basic example
I made a modification to the code in the experiment mentioned above:
pointLight.position.copy(camera.position);
progress += frameTime;
lastTimestamp = timestamp;
renderer.render(scene, camera);
stats.update();
requestAnimationFrame(animate);
And added this snippet:
pointLight.position.copy(camera.position);
progress += frameTime;
lastTimestamp = timestamp;
renderer.render(scene, camera);
stats.update();
requestAnimationFrame(animate);
var dataUrl = "#<!---->
var frame = 10;
$.ajax({
url: "http://127.0.0.1:8080",
type: "POST",
data: {"data": dataUrl, "frame": frame}
});
However, I still cannot locate the saved image file.