Cyn*_*hia 5 javascript ajax html5 canvas html5-canvas
我正在尝试在Canvas中构建一个平面图模型.目前,我的画布中有一个网格图像,用户可以通过单击并拖动鼠标来绘制线条.但是,这并不能保证直线.
无论如何,我可以在html页面中提供输入字段,供用户输入行的开始和结束x和y坐标,并在我的画布代码中更新它?我是JS/AJAX的初学者,所以任何补救的帮助都很受欢迎:)
现在,这是决定如何绘制线条的部分:
$(document).ready(function() {
var canvas = document.getElementById('canvas');
var context = canvas.getContext("2d");
if(canvas.getContext) {
$('#canvas').mousedown(function (evt) {
var offset = $('#canvas').offset();
context.beginPath();
context.moveTo(20, 20);
});
$(document).mousemove(function(evt) {
var offset = $('#canvas').offset();
context.lineTo(evt.pageX - offset.left, evt.pageY - offset.top);
context.stroke();
}).mouseup(function() {
$(document).unbind('mousemove');
$(document).unbind('mouseup');
});
$('#clearcanvas').click(function () {
context.clearRect(0, 0, 600, 580);
});
}
});
Run Code Online (Sandbox Code Playgroud)
我怀疑它涉及修改以下代码:
context.lineTo(evt.pageX - offset.left, evt.pageY - offset.top);
Run Code Online (Sandbox Code Playgroud)
很简单,您可以使用4个输入字段,并在按下按钮时获取每个输入字段的值
button.addEventListener('click', function() {
ctx.beginPath();
ctx.moveTo(x1.value, y1.value);
ctx.lineTo(x2.value, y2.value);
ctx.stroke();
}, false);
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
2224 次 |
| 最近记录: |