我正在尝试将我的 HTML 画布保存到我可以成功执行的文件中,但它没有保存我拖到画布中的任何对象。
因此,通过使用 Draggable JQuery,我可以愉快地在屏幕上移动我的对象并将其放置在我的画布上。当我使用它保存画布时,Canvas.ToDataURL()
它不会保存我拖动的对象(并且还在 jsFiddle 中对我的画布做了一些奇怪的事情,它似乎改变了我的画布的颜色?)。
要查看“工作”示例,请访问我的 jsFiddle http://jsfiddle.net/JVSFS/74/
请简单地将绿色框拖到蓝色框上,然后单击保存按钮。结果将显示在下方(只是一个橙色框)。
HTML
<canvas id="MyCanvas" class="canvas"></canvas>
<div class="popup_click">
<div id="popup_title">Drag</div>
</div>
<asp:HiddenField ID="hideMe" runat="server" />
<asp:Button runat="server" OnClick="ClickMe" Text="Click" OnClientClick="SaveMe()" />
<button onclick="SaveMe()">Try it</button>
<p>Results: </p>
<img id="myImage" />
JavaScript
$(document).ready(function () {
$('.popup_click').show(0).draggable();
});
function SaveMe() {
var canvas = document.getElementById("MyCanvas");
var context = canvas.getContext("2d");
context.fillStyle = "orange";
context.fillRect(0, 0, 100, 100);
var image = canvas.toDataURL("image/png");
document.getElementById("myImage").src = image;
document.getElementById("hideMe").value = image;
}
CSS
.popup_click {
background: #80FF80;
width: 50px; }
.canvas {
width: 100px;
height: 100px;
background-color: #0FC;
}
如何让拖动的对象保存?我假设我必须告诉 Canvas 该对象是它的上下文的一部分,但不知道如何并且我自己的搜索一无所获。