我最好用一张图片来解释我的问题
我有一个轮廓和一条穿过该轮廓的线。
在轮廓和线的交点处,我想在一条线和轮廓的交点处绘制一条垂直线,直到特定距离。
我知道交点以及线的斜率。
作为参考,我附上了这张图片。
如果你图片中的蓝线从 A 点到 B 点,而你想在 B 点画红线,你可以这样做:
v.x = B.x - A.x; v.y = B.y - A.y;
mag = sqrt (v.x*v.x + v.y*v.y); v.x = v.x / mag; v.y = v.y / mag;
temp = v.x; v.x = -v.y; v.y = temp;
C.x = B.x + v.x * length; C.y = B.y + v.y * length;
请注意,您可以通过简单地对 length 取反来创建一个相反方向的点 D,从而使其在两个方向上延伸。)这是我的功能版本:
def getPerpCoord(aX, aY, bX, bY, length):
vX = bX-aX
vY = bY-aY
#print(str(vX)+" "+str(vY))
if(vX == 0 or vY == 0):
return 0, 0, 0, 0
mag = math.sqrt(vX*vX + vY*vY)
vX = vX / mag
vY = vY / mag
temp = vX
vX = 0-vY
vY = temp
cX = bX + vX * length
cY = bY + vY * length
dX = bX - vX * length
dY = bY - vY * length
return int(cX), int(cY), int(dX), int(dY)