2015-12-12 21 views
0

使用canvas.toSVG如下所列:Creating a backing canvas with FabricJS我能到我的HTML5画布转换为SVG数据,看起来像这样通过调用canvas.toSVG():转换SVG数据到SVG文件可以上传

<?xml version="1.0" encoding="UTF-8" standalone="no" ?> 
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> 
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" width="85.999967in" height="55.812440in" style="background-color: #ffffff" viewBox="0 0 650 421.84" xml:space="preserve"> 
<desc>Created with Fabric.js 1.6.0-rc.1</desc> 
<defs></defs> 
<g transform="translate(516.24 217.93) scale(0.47 0.47)"> 
<image xlink:href="data:image/jpeg;base64,/9j/4AAQSkZJRgABAQEAyADIAAD/2wBDAAEBAQEBAQEBAQEBAQEB…lq4JVWvJFVClTiCkAAgF9IIBHyAQACB/oAf6+gMzMMVWDEN7kh5AkN0dEwR3++iCe/+ez9f//Z" x="-200" y="-193.5" style="stroke: none; stroke-width: 1; stroke-dasharray: none; stroke-linecap: butt; stroke-linejoin: miter; stroke-miterlimit: 10; fill: rgb(0,0,0); fill-rule: nonzero; opacity: 1;" width="400" height="387" preserveAspectRatio="none"></image> 
</g> 
</svg> 

但是,我需要能够通过AJX或节点(即请求或Unirest)将.svg文件上传到供应商API。

如何将上面的SVG/XML数据转换为可以保存然后上传的SVG文件?

这就是我使用的.png,但是当我使用乘法器时,大的画布升级会使浏览器崩溃,所以这就是为什么我试图使用SVG。巴布亚新几内亚自动Base64编码,所以在节点解码,传输到一个临时目录,然后贴如下:

客户端:

// Multiply Canvas 
     var img = canvas.toDataURL({ 
      // Multiplier appears to accept decimals 
      format: 'png', 
      multiplier: 5   
}); 

$http.post('/postVendor', { filename: filename, file: img }).success(function (data) {... 

服务器端/节点:

app.post('/postVendor', function (req, res, next) { 

    var filename = req.body.filename; 
    var file = req.body.file; 
    var fileloc = 'upload/' + filename; 

    //var base64Data; 
    fileBuffer = decodeBase64Image(file); 

    fs.writeFileSync('upload/' + filename, fileBuffer.data); 

unirest.post('http://myvendorsAPI/ws/fileuploads') 
.headers({ 'Content-Type': 'multipart/form-data' }) 
.field('filename', filename)// Form field 
.attach('file', fileloc)// Attachment 
.end(function (response) { 
     console.log(response.body); 
     //fs.unlinkSync(fileloc); 
     res.send(response.body); 
    }); 
}) 

由于toSVG输出XML,我将如何将其转换为SVG文件,以及如何上传?

+2

XML *是一个SVG文件SVG是一个基于XML的文件格式 –

+1

但是,你将赢得你的画布到这个svg:它只是一个包含在svg图像元素中的画布的JPEG版本,如果你想重新调整它,你将没有png版本更多的好处。 – Kaiido

+0

我能够将它作为XML来推送。具有.svg扩展名的文件从什么工作我可以说。它看起来很好,但我看到数据标签是jpeg。如果/可以改变? – Kode

回答

1
var file = canvas.toSVG({ 
     // Multiplier appears to accept decimals 
     width: '200mm', 
     height: '300mm'  

});

$ http.post( '/ postVendor',{文件名: 'myfile.svg',文件:文件})。成功(功能(数据){...}

在服务器端没有需要解码base64编码,因为你只是上传文本,urlencode从ajax应该就足够了

+0

这样做。看起来不错! – Kode