如何使用一串小椭圆而不是p5.js中常用的line()
函数来连接两个点?
我试图创建一个更“艺术”的函数来代替p5.js中常用的line()
函数。为了实现这一点,我想写一个函数,其中给定两个点(x,y)和(x1,y1),沿着连接两个点的线密集地和一致地绘制微小的圆圈。
我试着编写一个函数,首先查找所有可能的x和y点,然后使用条件,仅当i
和j
与(x1,y1)之间的斜率与(x,y)和(x1,y1)给定的斜率匹配时,才绘制椭圆。
这仅在(x,y)和(x1,y1)具有斜率0、1或未定义时给出我期望的结果;点间距随着任何其他斜率而显著变化。我不知道如何使点沿着我输入的任何线一致地放置。
我的职责如下:
function customLine(x, y, x1, y1) {
for (var i = x; i >= x && i <= x1; i ++) {
for (var j = y; j >= y && j <= y1; j ++) {
if ((j - y) / (i - x) == (y1 - y) / (x1 - x)) {
fill(0);
circle(i, j, 5);
}
}
}
}
我还附加了一张图像,显示了坡度值为0、未定义或1时获得的预期效果,但坡度为分数时则没有:output of above code, illustrating issue
我怎样才能修复我的函数?或者有没有更简单的方法来做这件事?非常感谢!
2条答案
按热度按时间ccgok5k51#
我认为这里最简单的方法是使用一些向量和三角函数,请尝试以下方法:
x0fgdtte2#
我认为您正在寻找两点之间的
lerp
(线性插值)。如果您希望间距保持一致并使用可变数量的点,则可以将两点之间的距离作为步数传递:
一个二个一个一个
或添加离散化: