Я нашел коды в вики Haskell "Алгоритма рисования линий Брезенхэма", однако я не могу легко понять часть начала, поэтому я переписал его.Но я не могу рисовать линии, когда уклон больше 1/2.Вот часть моих кодов.
line :: Point -> Point -> [Point]
line (x0,y0) (x1,y1)
| abs (y1-y0) > abs(x1-x0) = line (y0,x0) (y1,x1)
| x0 > x1 = line (x1,y1) (x0,y0)
| otherwise = plotLine x0 y0 0
where
И в предложении where я определяю функцию plotLine так же, как "go" в вики Haskell.Так как остальные мои коды почти такие же, как коды в вики Haskell, поэтому я думаю, что проблема с самого начала.Но я не могу понять это.Кто-нибудь может мне помочь?
Кстати, вот сайт «Алгоритма рисования линий Брезенхэма» на вики Haskell: https://wiki.haskell.org/Bresenham%27s_line_drawing_algorithm