我正在开发一个允许用户创建动态幻灯片的网络应用程序。目前,无论如何将计算机用户的图像添加到画布,我都遇到了问题。我正在使用输入按钮从计算机获取文件,它吸引了一个将图像添加到画布的函数。
到目前为止,我已经尝试了不同的方法将图像添加到画布以及这个:动态地将图像添加到画布
但是这里显示的代码在我的情况下不起作用,因为它只是将图像绘制到画布中,但它不允许它像 Fabricsjs 中的 Kitchensink.js 演示那样可拖动和调整大小。
我也尝试将图像转换为 Base64 并使用 LoadJSON 将其转换回来,但我遇到了这个错误:
Uncaught TypeError: Cannot read property 'length' of undefined fabric.js:2089
enlivenObjects fabric.js:2089
fabric.util.object.extend._enlivenObjects fabric.js:9025
fabric.util.object.extend.loadFromJSON fabric.js:8953
sub
Sub 指的是我为添加图像而调用的函数。
我也尝试过这段代码:
document.getElementById('imgLoader').onchange = function handleImage(e){
var reader = new FileReader();
reader.onload = function(event){
var img = new fabric.Image();
img.onload = function(){
img.set({
left : 250,
top : 250,
angle : 20,
padding: 10,
cornersize: 10
});
image.scale(getRandomNum(0.1, 0.25)).setCoords();
canvas.add(image);
}
img.src = event.target.result;
}
reader.readAsDataURL(e.target.files[0]);
}
捕获这些错误:
Uncaught TypeError: Cannot read property 'width' of undefined fabric.js:14358
fabric.Image.fabric.util.createClass._setWidthHeight fabric.js:14358
fabric.Image.fabric.util.createClass._initConfig fabric.js:14334
fabric.Image.fabric.util.createClass.setElement fabric.js:14127
fabric.Image.fabric.util.createClass._initElement fabric.js:14322
fabric.Image.fabric.util.createClass.initialize fabric.js:14097
(anonymous function) fabric.js:2679
klass fabric.js:2728
reader.onload diapo.js:746
我显然已经没有想法了,只实现了绘制图像但没有将其添加到画布中。
总之,我想将具有相同属性的图像添加到我的 Fabricjs 画布中,无论可拖动为 Kitchensink 演示。在此先感谢您的帮助 :)