How to save two canvas(outer and inner) as png using fabric js in angular(如何保存两个画布(外部和内部)为PNG使用织物js的角度)
本文介绍了如何保存两个画布(外部和内部)为PNG使用织物js的角度的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
当我保存画布时,它只保存外部画布,而忽略内部画布
//html
<button type="button" (click)="save()">save</button>
<div class="outercanvas">
<canvas id="outercanvas" width="500" height="500"></canvas>
</div>
<div class="outerCanvas">
<canvas id="outerCanvas" width="140" height="170" ></canvas>
</div>
//ts code
canvas = new fabric.Canvas('outercanvas');
canvas1 = new fabric.Canvas("innerCanvas");
save(){
window.open(this.canvas.toDataURL('png'));
}
推荐答案
Ofc,因为您从未要求它像保存外部Canvas那样保存内部Canvas。
save(){
window.open(this.canvas.toDataURL('png'));
}
若要将内部画布另存为单独,可以对内部画布调用相同的方法。
save(){
window.open(this.canvas.toDataURL('png')); //outercanvas
window.open(this.canvas1.toDataURL('png')); //innercanas
}
如果您要将两个画布保存在一个图像中,请按照以下步骤操作
- 获取内部画布的输出
- 使用
fabric.Image.fromURL()
将图像放置在外层画布上 - 保存外部画布的输出
- 将图像从外部画布中删除,这样就像图像永远不存在
注意:在第二步中,如果要使用canvas.centerObject(img);
这篇关于如何保存两个画布(外部和内部)为PNG使用织物js的角度的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:如何保存两个画布(外部和内部)为PNG使用织物js的角度


猜你喜欢
- Fetch API 如何获取响应体? 2022-01-01
- 400或500级别的HTTP响应 2022-01-01
- Css:将嵌套元素定位在父元素边界之外一点 2022-09-07
- Quasar 2+Apollo:错误:找不到ID为默认的Apollo客户端。如果您在组件设置之外,请使用ProvideApolloClient() 2022-01-01
- 如何使用 JSON 格式的 jQuery AJAX 从 .cfm 页面输出查 2022-01-01
- 使用RSelum从网站(报纸档案)中抓取多个网页 2022-09-06
- addEventListener 在 IE 11 中不起作用 2022-01-01
- 失败的 Canvas 360 jquery 插件 2022-01-01
- Flexslider 箭头未正确显示 2022-01-01
- CSS媒体查询(最大高度)不起作用,但为什么? 2022-01-01