我正在尝试从图片的右上角到左下角对角线绘制平行线。我希望它看起来像这样(可爱的油漆图片)
def diagTopLBottomR():
pic=makePicture(pickAFile())
w=getWidth(pic)
h=getHeight(pic)
x1=0
y1=0
x2=0
y2=0
i=0
while i<11:
x1=10*i
y2=10*i
i+=1
for y in range (y1,y2):
x = (y-y1)*(x2-x1)/(y2-y1) +x1
px=getPixel(pic,x,y)
color=makeColor(0,0,0)
setColor(px, color)
x3=0
y3=h
x4=w
y4=0
j=0
while j<10:
x3=10*j
y4=10*j
j+=1
for y in range (y3,y4):
x = (y-y3)*(x4-x3)/(y4-y3) +x3
px=getPixel(pic,x,y)
color=makeColor(0,0,0)
setColor(px, color)
return(pic)
您会注意到x3 要么是最大值,导致超出范围异常,要么 y 范围将从更高的值开始,即 (y3>y4) 并且不能反向工作,或者当我减少它时。这就像一个悖论。
第一个循环正在工作,无论我尝试什么,我都无法让第二个循环工作。这就是我要结束的。
有任何想法吗?谢谢。
编辑
我已经玩过范围,并且在第二个循环中没有得到任何结果,如上图所示的超出范围异常。
我努力了:
x3=0
y3=h
x4=w
y4=0
j=0
while j<10:
x3=10*j
y4=10*j
j+=1
for x in range (x3,x4):
y = (x-x3)*(y4-y3)/(x4-x3) +y3
从这里偷了独角兽。