javascript - HTML5 Canvas(绘图(矩形)不断消失)

标签 javascript iphone html canvas

最近怎么样?

最近,在本网站的帮助下,我学会了如何通过单击按钮在 HTML5 Canvas 上绘制矩形...这不是问题:) 问题是这个...不幸的是,每次我单击 Canvas 创建一个新矩形时,旧矩形就会消失(或立即被删除)。当我尝试在 iPod 上使用它时,它也根本不起作用...为什么:(?


这是我的代码:


JavaScript:

  // "Rectangle" Button
function rect()
{
var canvas = document.getElementById('canvasSignature'),
    ctx = canvas.getContext('2d'),
    rect = {},
    drag = false;


    function init() {
  canvas.addEventListener('mousedown', mouseDown, false);
  canvas.addEventListener('mouseup', mouseUp, false);
  canvas.addEventListener('mousemove', mouseMove, false);
}


function mouseDown(e) {
  rect.startX = e.pageX - this.offsetLeft;
  rect.startY = e.pageY - this.offsetTop;
  drag = true;
}


function mouseUp() {
  drag = false;
}


function mouseMove(e) {
  if (drag) {
    rect.w = (e.pageX - this.offsetLeft) - rect.startX;
    rect.h = (e.pageY - this.offsetTop) - rect.startY ;
    ctx.clearRect(0,0,canvas.width,canvas.height);
    draw();
  }
}


function draw() {
  ctx.fillRect(rect.startX, rect.startY, rect.w, rect.h);
}


init();
}

HTML5:

<div id="canvasDiv">
    <canvas id="canvasSignature" width="580px" height="788px" style="border:2px solid #000; background: #FFF;"></canvas>
</div>

<div id="rect">  
    <p><button onclick="rect();">Rectangle</button></p>
</div> 

任何帮助都将不胜感激:)

最佳答案

您有一个清除 Canvas 的声明

ctx.clearRect(0, 0, canvas.width, canvas.height);

关于javascript - HTML5 Canvas(绘图(矩形)不断消失),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10877222/

相关文章:

javascript - d3.js 饼图 - 图例切换

javascript - 如何使 Nodejsexpress.js(代理)服务器仅可用于特定域?

javascript - 如何在 meteor 中的服务器端套接字和html/javascript中的客户端套接字之间建立连接

javascript - Undefined 不是一个对象(评估 'navigator.permissions.query' )

html - 如何为 IMG 标签内的图像添加悬停边框?

javascript - react悬念如何保持在同一页面-LazyLoading

iphone - 具有半透明选定背景的 UITableViewCell

iphone - 无法使用phonegap写入文件

html - 页脚保持向下并与主要内容分开时遇到问题

php - Joomla 模块 Chrome 模块索引