javascript – 如何擦除画布而不擦除背景
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了javascript – 如何擦除画布而不擦除背景,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1112字,纯文字阅读大概需要2分钟。
内容图文
我有一个画布,我drawimage()作为背景.
我有一个橡皮擦工具,我希望能够擦除我绘制的内容,但不能删除画布中的图像.我知道可以将图像作为画布后面的单独元素放置,但这不是我想要的,因为我希望将画布中的内容保存为图像.
我的绘图功能在这里:
function draw (event) {
if (event == 'mousedown') {
context.beginPath();
context.moveTo(xStart, yStart);
} else if (event == 'mousemove') {
context.lineTo(xEnd, yEnd);
} else if (event == 'touchstart') {
context.beginPath();
context.moveTo(xStart, yStart);
} else if (event == 'touchmove') {
context.lineTo(xEnd, yEnd);
}
context.lineJoin = "round";
context.lineWidth = gadget_canvas.radius;
context.stroke();
}
如果我需要进一步解释,我会.
先感谢您.
解决方法:
有几种方法可以解决这个问题.
我建议把图像作为画布的CSS“background-image”.然后照常在画布上画画.
如果要将Canvas保存为图像,则需要执行一系列事件:
>创建与普通画布一样大的内存中画布.叫它can2
> ctx2.drawImage(can1,0,0)//将第一个画布绘制到新画布上
> ctx.clearRect(0,0,width,height)//清除第一个画布
> ctx.drawImage(background,0,0)//在第一个画布上绘制图像
> ctx.drawImage(can2,0,0)//将(已保存的)第一个画布绘制回自身
这将让您拥有两全其美.
内容总结
以上是互联网集市为您收集整理的javascript – 如何擦除画布而不擦除背景全部内容,希望文章能够帮你解决javascript – 如何擦除画布而不擦除背景所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。