Algorithme de droite

Pour tracer des droites avec peu de ressource

Durant mes études... j'ai travaillé sur un jeu de puissance 4 en assembleur, à cette occasion, j'ai eu à trouver une technique de tracé de droite et de cercle en minimisant les calculs.

J'ai découvert plus tard que cet algorithme avait déjà un nom. C'est celui de leur inventeur originel : Jack E. Bresenham

Vous trouverez ici ma forme de cet algorithme de tracé de droite.

Schéma

Point 1 (X1, Y1) : en bas à gauche
Point 2 (X2, Y2) : en haut à droite
Δx=X2-X1 : écart des abscisses
Δy=Y2-Y1 : écart des ordonnées

L'idée

La droite (D2) est la droite théorique tracée entre le point de départ et le point d'arrivée
La droite (D1) est la droite parallèle à (D) mais passant par le centre de A
La droite (D2) est la droite parallèle à (D) mais passant par le centre de B
L'idée est de choisir le point suivant pour lequel l'écart cumulé sera minimal.

Petits calculs

Equation de la droite (D) :
y=ax+b avec a=ΔyΔx et b=Y1-ΔyΔxX1
d'où (E):y=ΔyΔxx+b

Equation de la droite (D1) :
y'=ax'+b' avec a=ΔyΔx et b'=b+Δ1 et y'=y+1 et x'=x+1
d'où (E1):y+1=ΔyΔx(x+1)+b+Δ1
(E1-E):1=ΔyΔx+Δ1Δ1=1-ΔyΔx

Equation de la droite (D2) :
y'=ax'+b' avec a=ΔyΔx et b'=b+Δ2 et y'=y et x'=x+1
d'où (E2):y=ΔyΔx(x+1)+b+Δ2
(E2-E):0=ΔyΔx+Δ2Δ2=-ΔyΔx

Comme ce qui nous intéresse ce n'est pas la valeur même mais l'ordre de grandeur de Δ1 par rapport à Δ2, on les multiplie par Δx :
Δ'1=Δx-Δy
Δ'2=-Δy

Comme ce n'est pas forcément pratique de comparer des valeurs absolues dans l'algorithme, on ne va pas comparer |Δ'1| avec |Δ'2| mais plutôt |Δ'2|-|Δ'1| avec 0 d'où l'expression 2ΔY-ΔX et les suivantes que vous allez voir ci-dessous.

Algorithme

Cet algorithme a comme syntaxe une syntaxe très basique.
A vous de la traduire dans le language qu'il vous plaira.

Dans cet algorithme je ne me limite pas au premier quadrant comme vu ci-dessus pour exprimer les formules.

X=X1
Y=Y1
ΔX=|X2-X1|
ΔY=|Y2-Y1|
Affiche_Pixel(X, Y)

1er quadrant

Si X1X2 et Y1Y2 Alors # en dessous 1ere bissectrice
Si X2-X1Y2-Y1 Alors Δ=2ΔY-ΔX
Tant que X<>X2
X=X+1
Si Δ>0 Alors
Y=Y+1
Δ=Δ-2ΔX
Δ=Δ+2ΔY
Affiche_Pixel(X, Y)
# au dessus 1ere bissectrice
Sinon Δ=2ΔX-ΔY
Tant que Y<>Y2
Y=Y+1
Si Δ>0 Alors
X=X+1
Δ=Δ-2ΔY
Δ=Δ+2ΔX
Affiche_Pixel(X, Y)

2ème quadrant

Si X1>X2 et Y1<Y2 Alors
# en dessous 2e bissectrice
Si X1-X2Y2-Y1 Alors
Δ=2ΔY-ΔX
Tant que X<>X2
X=X-1
Si Δ>0 Alors
Y=Y+1
Δ=Δ-2ΔX
Δ=Δ+2ΔY
Affiche_Pixel(X, Y)
# au dessus 2e bissectrice
Sinon
Δ=2ΔX-ΔY
Tant que Y<>Y2
Y=Y+1
Si Δ>0 Alors
X=X-1
Δ=Δ-2ΔY
Δ=Δ+2ΔX
Affiche_Pixel(X, Y)

3ème quadrant

Si X1X2 et Y1Y2 Alors
# en dessous 3e bissectrice
Si X1-X2Y1-Y2 Alors
Δ=2ΔY-ΔX
Tant que X<>X2
X=X-1
Si Δ>0 Alors
Y=Y-1
Δ=Δ-2ΔX
Δ=Δ+2ΔY
Affiche_Pixel(X, Y)
# au dessus 3e bissectrice
Sinon
Δ=2ΔX-ΔY
Tant que Y<>Y2
Y=Y-1
Si Δ>0 Alors
X=X-1
Δ=Δ-2ΔY
Δ=Δ+2ΔX
Affiche_Pixel(X, Y)

4ème quadrant

Si X1<X2 et Y1>Y2 Alors
# en dessous 4e bissectrice
Si X2-X1Y1-Y2 Alors
Δ=2ΔY-ΔX
Tant que X<>X2
X=X+1
Si Δ>0 Alors
Y=Y-1
Δ=Δ-2ΔX
Δ=Δ+2ΔY
Affiche_Pixel(X, Y)
# au dessus 4e bissectrice
Sinon
Δ=2ΔX-ΔY
Tant que Y<>Y2
Y=Y-1
Si Δ>0 Alors.
X=X+1
Δ=Δ-2ΔY
Δ=Δ+2ΔX
Affiche_Pixel(X, Y)