gpt4 book ai didi

javascript - 如何在给定用户输入 X、Y 点的情况下绘制 HTML5 Canvas 线?

转载 作者:太空狗 更新时间:2023-10-29 15:57:46 24 4
gpt4 key购买 nike

我正在尝试在 Canvas 中构建平面图模型。目前,我的 Canvas 中有一个网格图像,用户可以通过单击和拖动鼠标来绘制线条。但是,这并不能保证直线。

我是否可以在 html 页面中提供输入字段供用户输入线条的开始和结束 x 和 y 坐标,并在我的 Canvas 代码中更新它?我是 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);
});
}
});

我怀疑它涉及修改以下代码:

context.lineTo(evt.pageX - offset.left, evt.pageY - offset.top);

最佳答案

非常简单,您可以使用 4 个输入字段并在按下按钮时获取每​​个字段的值

button.addEventListener('click', function() {
ctx.beginPath();
ctx.moveTo(x1.value, y1.value);
ctx.lineTo(x2.value, y2.value);
ctx.stroke();
}, false);

http://jsfiddle.net/TeGGx/

关于javascript - 如何在给定用户输入 X、Y 点的情况下绘制 HTML5 Canvas 线?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8379736/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com