我正在尝试将画布作为图像发送到服务器,并且希望以base64的形式发送。Fabricjs提供了使用canvas.toSVG()
或canvas.toDataURL({format: 'image/png'})
将画布转换为图像的方法,但是我的日志中的输出似乎是一个Klass对象(第一次看到该对象),并且将该对象发送到服务器并记录了服务器上收到的内容后,我得到了一个空对象或路径,即:
{ version: '2.0.0-rc.3', objects: [] }
{ version: '2.0.0-rc.3',
objects:
[ { type: 'path',
version: '2.0.0-rc.3',
originX: 'left',
originY: 'top',
left: 156.21249771118164,
top: 221.20000457763672,
width: 132,
height: 53,
fill: null,
stroke: 'Red',
strokeWidth: 10,
strokeDashArray: null,
strokeLineCap: 'round',
strokeLineJoin: 'round',
strokeMiterLimit: 10,
scaleX: 1,
scaleY: 1,
angle: 0,
flipX: false,
flipY: false,
opacity: 1,
shadow: null,
visible: true,
clipTo: null,
backgroundColor: '',
fillRule: 'nonzero',
paintFirst: 'fill',
globalCompositeOperation: 'source-over',
transformMatrix: null,
skewX: 0,
skewY: 0,
path: [Object] } ] }
Klass对象控制台图像:
我的代码:
var canvas = new fabric.Canvas();
canvas.loadFromJSON(val[i].story); //val has saved canvas
canvas.toSVG(); //or to dataURL()
我尝试了这个并且还是相同的klass对象,需要将canvas转换为base64图像(首选png),然后发送到服务器,在这里我将转换为图像文件,谢谢。
因此,在创建画布时,我缺少了画布的ID。
var canvas = new fabric.Canvas('canvasID');
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句