Javascript 在html5中将画布转换为具有背景图像的图像

Javascript 在html5中将画布转换为具有背景图像的图像,javascript,html,twitter-bootstrap,canvas,fabricjs,Javascript,Html,Twitter Bootstrap,Canvas,Fabricjs,我实现了将画布转换为图像,但当我设置背景图像时,它将不起作用。 我将fabric js用于画布,但每当我设置背景图像时,画布不会在图像中转换。设置背景图像后,我点击我的点击!!最后的图像应该来了。 我有一个Jffidle。 Html: 正如帕特里克·埃文斯告诉你的,你有一个 幸运的是,您在问题中指出的图像来自一个域,该域确实发送了适当的头,以便通过跨域使用 为此,必须设置setBackgroundImage()方法的crossOrigin参数: var canvas=newfabric.ca

我实现了将画布转换为图像,但当我设置背景图像时,它将不起作用。 我将fabric js用于画布,但每当我设置背景图像时,画布不会在图像中转换。设置背景图像后,我点击我的点击!!最后的图像应该来了。 我有一个Jffidle。

Html:


正如帕特里克·埃文斯告诉你的,你有一个

幸运的是,您在问题中指出的图像来自一个域,该域确实发送了适当的头,以便通过跨域使用

为此,必须设置
setBackgroundImage()
方法的
crossOrigin
参数:

var canvas=newfabric.canvas('canvas');
canvas.setBackgroundImage('https://c1.staticflickr.com/5/4051/4510967899_293f0dd5ac_z.jpg', 
canvas.renderal.bind(canvas),
//这里设置crossOrigin属性
{crossOrigin:'匿名'}
);
document.getElementById('file').addEventListener(“更改”,函数(e){
var file=e.target.files[0];
var reader=new FileReader();
控制台日志(“读卡器”+读卡器);
reader.onload=函数(f){
var数据=f.target.result;
fabric.Image.fromURL(数据、函数(img)){
var oImg=img.set({
左:70,
前100名,
宽度:250,
身高:200,
角度:0
}).比例(0.9);
canvas.add(oImg.renderAll();
canvas.setActiveObject(oImg);
});
};
reader.readAsDataURL(文件);
});
document.querySelector('#txt').onclick=function(e){
e、 预防默认值();
canvas.deactivateAll().renderAll();
document.querySelector('#preview').src=canvas.toDataURL();
};

从这里定制T恤



正如帕特里克·埃文斯(Patrick Evans)告诉你的,你有一个

幸运的是,您在问题中指出的图像来自一个域,该域确实发送了适当的头,以便通过跨域使用

为此,必须设置
setBackgroundImage()
方法的
crossOrigin
参数:

var canvas=newfabric.canvas('canvas');
canvas.setBackgroundImage('https://c1.staticflickr.com/5/4051/4510967899_293f0dd5ac_z.jpg', 
canvas.renderal.bind(canvas),
//这里设置crossOrigin属性
{crossOrigin:'匿名'}
);
document.getElementById('file').addEventListener(“更改”,函数(e){
var file=e.target.files[0];
var reader=new FileReader();
控制台日志(“读卡器”+读卡器);
reader.onload=函数(f){
var数据=f.target.result;
fabric.Image.fromURL(数据、函数(img)){
var oImg=img.set({
左:70,
前100名,
宽度:250,
身高:200,
角度:0
}).比例(0.9);
canvas.add(oImg.renderAll();
canvas.setActiveObject(oImg);
});
};
reader.readAsDataURL(文件);
});
document.querySelector('#txt').onclick=function(e){
e、 预防默认值();
canvas.deactivateAll().renderAll();
document.querySelector('#preview').src=canvas.toDataURL();
};

从这里定制T恤



您应该会在控制台上收到一条消息。在中国,受污染的画布可能无法出口。这意味着您从外部域添加图像的画布无法保存。对于类似的情况,我使用BASE64转换图像作为背景。但同样,它为您提供了大约30%的内存开销。“一定有别的办法可以做到。”帕特里克。当我删除背景图像时,它就工作了。你应该在控制台上收到一条消息。在中国,受污染的画布可能无法出口。这意味着您从外部域添加图像的画布无法保存。对于类似的情况,我使用BASE64转换图像作为背景。但同样,它为您提供了大约30%的内存开销。“一定有别的办法可以做到。”帕特里克。当我删除背景图像时,它就正常工作了。
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://rawgit.com/kangax/fabric.js/master/dist/fabric.min.js"></script>
 <div class="col-sm-12">                    
      <div class="text-center" style="font-size:25;margin-top:17px;margin-bottom: 30px;"><strong>Customize T-Shirt From Here</strong></div>
             <input type="file" id="file">            
             <br/>
              <canvas id="canvas" width="750" height="550" style="border: 1px solid black;  box-shadow: rgba(0,0,0,0.8) 0 0 10px;"></canvas>
              <a href='' id='txt' target="_blank">Click Me!!</a><br />
              <img id="preview" />
  </div>
 var canvas = new fabric.Canvas('canvas');

            // initialize fabric canvas and assign to global windows object for debug         

            canvas.setBackgroundImage('https://c1.staticflickr.com/5/4051/4510967899_293f0dd5ac_z.jpg', canvas.renderAll.bind(canvas), {
            });



            document.getElementById('file').addEventListener("change", function (e) {
                var file = e.target.files[0];
                var reader = new FileReader();
                console.log("reader   " + reader);
                reader.onload = function (f) {

                    var data = f.target.result;
                    fabric.Image.fromURL(data, function (img) {
                        var oImg = img.set({left: 70, top: 100, width: 250, height: 200, angle: 0}).scale(0.9);
                        canvas.add(oImg).renderAll();
                        canvas.setActiveObject(oImg);
                    });
                };
                reader.readAsDataURL(file);
            });

            document.querySelector('#txt').onclick = function (e) {
                e.preventDefault();
                canvas.deactivateAll().renderAll();                
                document.querySelector('#preview').src = canvas.toDataURL();
            };