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