所以基本上我試圖發送WebGL幀/屏幕截圖到一個服務器,可以將這些幀保存到硬盤驅動器,這樣我就可以將這些保存的幀合併到視頻文件中。 我發現這一點: Exporting video from webgl如何編寫包含兩段POST數據的AJAX請求?
我不喜歡打擾你們用WebGL的相關細節......你應該知道,我想送兩個客戶端的內容唯一的JavaScript變量localhost node.js服務器。所以,這兩個客戶端變量如下:
var frame = frame + 1; //this is the frame counter
var dataUrl = renderer.domElement.toDataURL("image/png"); //this is the encoded screenshot/frame
接收服務器端代碼被喬特納給出的(這在node.js中運行)。 所以我的問題是:如何將上面提到的兩個變量的內容發送到這個node.js代碼?
var http = require('http');
var querystring = require('querystring');
var fs = require('fs');
// Override so we don't decode spaces, and mess up the base64 encoding
querystring.unescape = function(s, decodeSpaces) {
return s;
};
// Pad to follow the processing 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");
我應該這樣做嗎?
...
...
//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}
});
...
...
例如,讓我們看看這個實驗:
pointLight.position.copy(camera.position);
progress += frameTime;
lastTimestamp = timestamp;
renderer.render(scene, camera);
stats.update();
requestAnimationFrame(animate);
向該:
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}
});
我在上述實驗中改變這一段代碼
但仍看不到任何保存的圖像文件。
[通行證陣列以在$就()AJAX請求]的可能重複(HTTP:/ /stackoverflow.com/questions/8890524/pass-array-to-ajax-request-in-ajax) – bwright