2017-01-27 84 views
0

我來這裏爲HTML/Javascript中的一個乾淨的畫布問題。在此畫布中,它用於簽名(如this)。HTML/Javascript清潔畫布

如果我使用這些代碼:

var canvas, ctx, flag = false, 
 
    prevX = 0, 
 
    currX = 0, 
 
    prevY = 0, 
 
    currY = 0, 
 
    dot_flag = false; 
 

 
var x = "black", 
 
    y = 2; 
 

 
function save() { 
 
    var canvas = document.getElementById("can"); 
 
    var dataURL = canvas.toDataURL("image/png"); 
 
    document.getElementById('source').value = dataURL; 
 
    var fd = new FormData(document.forms["general"]); 
 

 
    var xhr = new XMLHttpRequest(); 
 
    xhr.open('Get', 'convertToPdf.php', true); 
 

 
    xhr.upload.onprogress = function(e) { 
 
    if (e.lengthComputable) { 
 
     var percentComplete = (e.loaded/e.total) * 100; 
 
     console.log(percentComplete + '% uploaded'); 
 
     alert('Succesfully uploaded'); 
 
    } 
 
    }; 
 

 
    xhr.onload = function() { 
 

 
    }; 
 
    xhr.send(fd); 
 
} 
 

 
function color(obj) { 
 
    switch (obj.id) { 
 
    case "green": 
 
     x = "green"; 
 
     break; 
 
    case "blue": 
 
     x = "blue"; 
 
     break; 
 
    case "red": 
 
     x = "red"; 
 
     break; 
 
    case "yellow": 
 
     x = "yellow"; 
 
     break; 
 
    case "orange": 
 
     x = "orange"; 
 
     break; 
 
    case "black": 
 
     x = "black"; 
 
     break; 
 
    case "white": 
 
     x = "white"; 
 
     break; 
 
    } 
 
    if (x == "white") y = 14; 
 
    else y = 2; 
 

 
} 
 

 
function draw() { 
 
    ctx.beginPath(); 
 
    ctx.moveTo(prevX, prevY); 
 
    ctx.lineTo(currX, currY); 
 
    ctx.strokeStyle = x; 
 
    ctx.lineWidth = y; 
 
    ctx.stroke(); 
 
    ctx.closePath(); 
 
} 
 

 
function erase() { 
 
    var m = confirm("Want to clear"); 
 
    if (m) { 
 
    ctx.clearRect(0, 0, w, h); 
 
    document.getElementById("canvasimg").style.display = "none"; 
 
    } 
 
    var conv = new ActiveXObject("pdfServMachine.converter"); 
 
    conv.convert("http://www.google.com", "google.pdf", false); 
 
    WScript.Echo("finished conversion"); 
 
} 
 

 

 
function findxy(res, e) { 
 
    if (res == 'down') { 
 
    prevX = currX; 
 
    prevY = currY; 
 
    currX = e.clientX - canvas.offsetLeft; 
 
    currY = e.clientY - canvas.offsetTop; 
 

 
    flag = true; 
 
    dot_flag = true; 
 
    if (dot_flag) { 
 
     ctx.beginPath(); 
 
     ctx.fillStyle = x; 
 
     ctx.fillRect(currX, currY, 2, 2); 
 
     ctx.closePath(); 
 
     dot_flag = false; 
 
    } 
 
    } 
 
    if (res == 'up' || res == "out") { 
 
    flag = false; 
 
    } 
 
    if (res == 'move') { 
 
    if (flag) { 
 
     prevX = currX; 
 
     prevY = currY; 
 
     currX = e.clientX - canvas.offsetLeft; 
 
     currY = e.clientY - canvas.offsetTop; 
 
     draw(); 
 
    } 
 
    } 
 
}
<p align="center"> 
 
    <canvas id="can" width="700" height="200" style="border:2px solid;"></canvas> 
 
</p> 
 
<table align="center"> 
 
    <tr align="left"> 
 
    <td align="right"> 
 
     <input type="submit" name="ss" value="Submit" id="btn" onclick="save();return validateBeforeSubmit(); "> 
 
    </td> 
 
    <td align="right"> 
 
     <input type="button" name="ss" value="clear" id="btn" onclick="erase()"> 
 
    </td> 
 
    </tr> 
 
</table>

清晰的,工作的,但如果我在頁面上有一個滾動條,我們不能看到在畫布上的東西! !

所以,我一直在尋找一個function init(),將能夠無論你在網頁在畫布上寫,發現這個:

function init(){ 
 
    var canvas = document.getElementById('can'); 
 
    var ctx = canvas.getContext('2d'); 
 
    w = canvas.width; 
 
    h = canvas.height; 
 

 
    var x = null; 
 
    var y; 
 
    
 
    canvas.onmousedown = function(e){ 
 
    x = e.pageX - canvas.offsetLeft; 
 
    y = e.pageY - canvas.offsetTop; 
 
    ctx.beginPath(); 
 
    ctx.moveTo(x,y); 
 
    } 
 
    
 
    canvas.onmouseup = function(e){ 
 
    x = null; 
 
    } 
 
    
 
    canvas.onmousemove = function(e){ 
 
    if (x==null) return; 
 
    x = e.pageX - canvas.offsetLeft; 
 
    y = e.pageY - canvas.offsetTop; 
 
    ctx.lineTo(x,y); 
 
    ctx.stroke(); 
 
    } 
 
}

但是要知道,在畫布上取所有'簽名',因此,如果網頁有一個滾動條,沒有問題,畫布仍然顯示一些東西,如果你畫一些東西,但明確不會在它上面工作。

所以,我的問題是我希望能夠在畫布上寫字,不管它在哪裏,並且如果點擊我的按鈕的功能清晰,就可以清除畫布。

編輯 這裏我的網頁是什麼樣子: My page

現在,我把它無需滾動條來顯示,但在原來的大小,頁面有一個滾動。我的畫布位於頁面的底部,因此,當我向下滾動時,我無法繪製它,但在沒有滾動的頁面中,我可以繪製它並將其擦除!

原因是我把第二個init function,如果有滾動條或不滾動,我仍然可以在它中畫,我滾動或不滾動頁面,但不是爲了清潔它!

感謝你的幫助

+0

道歉,我很樂意幫忙,但我很難理解。您提供的代碼段似乎沒有按照您的預期工作。你能提供一個jsfiddle(https://jsfiddle.net/)嗎?其次,當你說你希望能夠在畫布上書寫時,你是否可以更清楚地表達你的意思,不管它在哪裏? – zfrisch

+0

我想你的意思是這個https:// jsfiddle。net/we242fmt/1/ 現在,如果您在沒有滾動條的網頁中使用腳本,我們可以繪製它(例如,如果您進入繪畫並繪製東西)。但是,每次將它放在使用滾動條的網頁上時,如果在畫布上繪製它,它就在網頁的末尾,所以沒有任何反應,這就是爲什麼找到能夠在畫布上繪製的其他初始化函數,如果這一個在頂部還是在底部 – Nexis

回答

0

https://jsfiddle.net/we242fmt/3/

(在這個例子中我特意搬到畫布上向下用CSS來更好的展示頁面,可以刪除我已在找回CSS到你所在的位置)

發生什麼事是你得到了canvas元素的偏移量,但偏移量沒有考慮你向下滾動頁面的距離。

所有我們需要做的僅僅是調整代碼納入用戶已滾動的距離:

 currX = e.clientX - canvas.offsetLeft + window.scrollX; 
     currY = e.clientY - canvas.offsetTop + window.scrollY; 

在你的榜樣,你不需要使用scrollX因爲你沒有水平滾動,但爲了徹底,我將它包含在內。

+1

啊啊!!真的,謝謝,這是現在的工作! – Nexis

+0

@Nexis這沒問題! – zfrisch

+0

嗨zfrisch, 你知道爲什麼在ie,這是讓我一個錯誤? 它在Firefox和Chrome中運行良好,但在Internet Explorer中無所作爲。 – Nexis