2015-07-10 94 views
0

所以基本上我試圖發送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}  
     }); 

Three.js basic example

我在上述實驗中改變這一段代碼

但仍看不到任何保存的圖像文件。

+0

[通行證陣列以在$就()AJAX請求]的可能重複(HTTP:/ /stackoverflow.com/questions/8890524/pass-array-to-ajax-request-in-ajax) – bwright

回答

1

你寫的代碼,只需要在其URL正確的協議(你失蹤「的http://」):

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}  
}); 

從您發佈的代碼,你可以看到服務器已經解析請求,並提取您在POST發送兩個參數

if (request.content.trim()) {  
    request.content = querystring.parse(request.content); 
    var data = request.content['data']; 
    var frame = request.content['frame']; 
    //... 

任何你添加到$就POST請求可以通過名稱檢索調用

request.content['name'] 

只要確保您在客戶端和服務器代碼中使用的名稱相匹配即可。

此外,Node.js的代碼被接收逃脫的base64字符串,不使此功能工作

data.substr(data.indexOf(',') + 1); 

因爲「」字符轉義。

爲了解決這個只使用節點內置函數UNESCAPE上的數據串這樣

var data = unescape(request.content['data']); 
+0

這很好,糾正了我的代碼,但node.js仍然不顯示任何內容或不保存任何圖片。應該在哪裏由node.js保存圖片? – Fract

+1

我在更正了數據變量後,更新了我的答案,服務器正確保存圖像。這些圖片保存在您執行** node.js的目錄中。如果你想使用一個特定的目錄,只需在文件名'fs.writeFile(directoryPath +'screen-'+ pad(frame)+'.png',...)之前加上它' – Sosdoc

+0

在我指定的目錄路徑上沒有圖像。我是node.js的新手。因此,請重新檢查如何使用上面的腳本啓動node.js。我將上面的node.js相關代碼複製並粘貼到文本文件(xy.txt)中,然後進入cmd(其中發生xy.txt)並鍵入「node xy.txt」。 我只看到一個黑屏。沒有圖像創建。 – Fract