Ligne en pointillés dans canvas
Style en javascript
… ou comment tracer des lignes en pointillés (line style: dashed)
On trace une ligne en pointillés en alternant de courts segments.
La fonction globale DashedLine(xA,yA,xB,yB,L,l) trace ceci, en utilisant 6 paramètres:
-
et
: les coordonnées du point
, une des deux extrémités du segment
-
et
: les coordonnées du point
, l'autre extrémité du segment
-
et
les deux longueurs, en pixels, respectivement de la longueur des tirets utilisés et de l'espacement entre chque tiret.
![\psset{unit=1.2cm}\begin{pspicture}(-.5,-.5)(8.2,1.8)
\newcommand{\f}[1]{#1 .7 add}
\multido{\i=0+1}{8}{\psline[linewidth=1.8pt](\i,1)(! \f{\i}\space1)}
\psline[linewidth=.3pt](2,1.2)(2,0)
\psline[linewidth=.3pt](2.7,1.2)(2.7,0)
\psline[arrowsize=6pt,linewidth=.3pt]{<->}(2.,.2)(2.7,.2)
\rput(2.35,-.1){$L$}
\psline[linewidth=.3pt](4.7,1.2)(4.7,0)
\psline[linewidth=.3pt](5,1.2)(5,0)
\psline[arrowsize=6pt,linewidth=.3pt]{->}(4.2,.2)(4.7,.2)
\psline[arrowsize=6pt,linewidth=.3pt]{<-}(5,.2)(5.5,.2)
\psline[linewidth=.3pt](4.7,.2)(5,.2)
\rput(4.85,-.1){$l$}
\rput(0,.98){$\bullet$}\rput(0,1.2){$A$}
\rput(7.7,.98){$\bullet$}\rput(7.7,1.2){$B$}
\end{pspicture}](canvas-line-style-pointilles-dashed-IMG/11.png)
Exemples de valeurs pour
data:image/s3,"s3://crabby-images/f7db4/f7db4c2425ebae3c6589b76ad132a33e554eb9ee" alt="$L$"
data:image/s3,"s3://crabby-images/f141f/f141f54690ea28c78c932abb83187570ec90ec96" alt="$l$"
![\psset{unit=1.2cm}\begin{pspicture}(-.3,-.3)(8.2,2.7)
\newcommand{\f}[1]{#1 .7 add}
\multido{\i=0+1}{8}{\psline[linewidth=1.5pt](\i,2)(! \f{\i}\space2)}
\rput[l](0,2.2){$L=0,7$, $l=0,3$}
\renewcommand{\f}[1]{#1 .9 add}
\multido{\i=0+1}{8}{\psline[linewidth=1.5pt](\i,1)(! \f{\i}\space1)}
\rput[l](0,1.2){$L=0,9$, $l=0,1$}
\renewcommand{\f}[1]{#1 .5 add}
\multido{\i=0+1}{8}{\psline[linewidth=1.5pt](\i,0)(! \f{\i}\space0)}
\rput[l](0,.2){$L=l=0,5$}
\end{pspicture}](canvas-line-style-pointilles-dashed-IMG/14.png)
Code javascript et exemples d'utilisation
- Code: Select all
-
<canvas id="canvas" width="300" height="200" style="border: 2px solid black;"></canvas>
<script>
canvas = document.getElementById("canvas");
ctx = canvas.getContext("2d");
function Norm(xA,yA,xB,yB) {return Math.sqrt(Math.pow(xB-xA,2)+Math.pow(yB-yA,2));}
function DashedLine(xA,yA,xB,yB,L,l) {
Nhatch=Norm(xA,yA,xB,yB)/(L+l);
x1=xA;y1=yA;
for (i=0;i < Nhatch; i++) {
newXY=Hatch(xA,yA,xB,yB,x1,y1,L);
x2=newXY[0];y2=newXY[1];
ctx.beginPath();ctx.moveTo(x1,y1);ctx.lineTo(x2,y2);ctx.stroke();
newXY=Hatch(xA,yA,xB,yB,x2,y2,l);
x1=newXY[0];
y1=newXY[1];
}
}
function Hatch(xA,yA,xB,yB,x1,y1,l) {
a=(yB-yA)/(xB-xA);b=yA-a*xA;// Equation reduite y=ax+b de (AB):
if ((xB-xA)>0) {sgn=1;} else {sgn=-1;}
x2=sgn*l/Math.sqrt(1+a*a)+x1;
y2=a*x2+b;
if (Norm(x1,y1,x2,y2)>Norm(x1,y1,xB,yB)) {x2=xB;y2=yB;}
return [x2,y2];
}
// Et 4 exemples d'utilisation:
xA=10;yA=20;
xB=200;yB=50;
DashedLine(xA,yA,xB,yB,20,5);
ctx.strokeStyle = "red";ctx.lineWidth=3;
xA=10;yA=50;xB=250;yB=100;
DashedLine(xA,yA,xB,yB,20,5);
ctx.strokeStyle = "green";ctx.lineWidth=2;
xA=10;yA=160;xB=250;yB=130;
DashedLine(xA,yA,xB,yB,50,5);
ctx.strokeStyle = "blue";
xA=10;yA=180;xB=280;yB=180;
DashedLine(xA,yA,xB,yB,2,2);
</script>
- Affichage:
Détails et explications sur le code et les calculs effectués
Pour tracer cette ligne pointillée, on part du point
data:image/s3,"s3://crabby-images/1b270/1b270a1b85b3b8972a47bcbe31e3726a25600e06" alt="$M_1\lp x_1;y_1\rp$"
data:image/s3,"s3://crabby-images/2f6af/2f6af9ef6b11bd0c67743a747dfe76cd804dc8f0" alt="$A\lp x_A;y_A\rp$"
data:image/s3,"s3://crabby-images/a1d50/a1d508bea5c693adb2192704d516788bd6a0285b" alt="$x_1=x_A$"
data:image/s3,"s3://crabby-images/ae9f8/ae9f8f0938b78c5c38432f0083c86d8407e91185" alt="$y_1=y_A$"
On cherche alors le point
data:image/s3,"s3://crabby-images/8d0e2/8d0e27f10a0617d974d321d7c4815dba14276a56" alt="$M_2\lp x_2;y_2\rp$"
data:image/s3,"s3://crabby-images/33b48/33b480eb9854b620e78d76c5e3741c81bc582b46" alt="$M_1M_2=L$"
![$M_2\in[M_1;B]$](canvas-line-style-pointilles-dashed-IMG/21.png)
![$[M_1M_2]$](canvas-line-style-pointilles-dashed-IMG/22.png)
On réitère ensuite en prenant
data:image/s3,"s3://crabby-images/68dc8/68dc88f1582252bd3663dbdddb1370e9e6a10fba" alt="$M_1=M_2$"
data:image/s3,"s3://crabby-images/bd12a/bd12a4b5a26f7ce06e5ae916a8ec4aa1f607d8d8" alt="$M_2$"
data:image/s3,"s3://crabby-images/dcb27/dcb27599f95b61e4ad043c1a40812d41f3473784" alt="$M_1M_2=l$"
data:image/s3,"s3://crabby-images/cb7b3/cb7b3e1f89c335ae4412d7561386228f5a909e06" alt="$M_1M_2$"
On recommence ensuite…
Cette boucle est implémentée dans la fonction DashedLine.
Il reste à déterminer les coordonnées du point
data:image/s3,"s3://crabby-images/d3ffa/d3ffa73eb238077d874c7fa09e4ef7fc1ad6dfa1" alt="$M_2\lp x_2;y_2\rp$"
Détails de la fonction Hatch
On cherche donc les coordonnéesdata:image/s3,"s3://crabby-images/863fe/863fe6933a2a214b48b934b72d5f871625fdb2fa" alt="$\lp x_2;y_2\rp$"
data:image/s3,"s3://crabby-images/a264f/a264fb67ed81040edb60158f1837b7ea980c52d0" alt="$M_2$"
data:image/s3,"s3://crabby-images/ce598/ce5986b3b484ee7053fc6acf39d5debbbaca085b" alt="$M_1M_2=L$"
data:image/s3,"s3://crabby-images/83530/8353060a626d8b84abafe109079f8f10a3d5c6ab" alt="$M_2\in(AB)$"
![$M_2\in[M_1;B]$](canvas-line-style-pointilles-dashed-IMG/32.png)
Tout d'abord, si on connaît l'équation réduite
data:image/s3,"s3://crabby-images/38591/38591a5e89d6231e51c9fa3a3df87efb49700ccc" alt="$y=ax+b$"
data:image/s3,"s3://crabby-images/1f2ec/1f2ec9159fc2cf6de36115675a9814be47f3f037" alt="$(AB)$"
data:image/s3,"s3://crabby-images/cb75b/cb75b61feea3edabc3793243f6e84e623960a948" alt="$M_2\in(AB)$"
data:image/s3,"s3://crabby-images/ee3ef/ee3ef0cb2c8812ffd910ef0edb2e68126558b61e" alt="$y_2=ax_2+b$"
Equation réduite de la droite
L'équation réduite s'écrit data:image/s3,"s3://crabby-images/a0a2e/a0a2ea71e396072d72745c132b108663441c8b5b" alt="$y=ax+b$"
Le coefficient directeur
data:image/s3,"s3://crabby-images/429a1/429a168e617c27825bf494347e80aa0fd7225f9c" alt="$a$"
data:image/s3,"s3://crabby-images/8a6ee/8a6eedc40268e08d6b8bc5d6d6836adb2e324c28" alt="$a=\dfrac{\Delta y}{\Delta x}=\dfrac{y_B-y_A}{x_B-x_A}$"
Ensuite, comme par exemple
data:image/s3,"s3://crabby-images/71b42/71b4257463ca0b0809c86b7957efdd8119f625ca" alt="$A\in(AB)$"
data:image/s3,"s3://crabby-images/e0112/e011223c141940a3100c23db4c32836c2368b345" alt="$y_A=ax_A+b$"
data:image/s3,"s3://crabby-images/66fc9/66fc9b84d4730b194eaef3340f161face65372c9" alt="$b$"
data:image/s3,"s3://crabby-images/61da0/61da04be2540f208f61719f4f9aeefabb522fe4d" alt="$b=y_A-ax_A$"
On calcule ainsi simplement les coefficients
data:image/s3,"s3://crabby-images/407eb/407ebeca45b1e59d4ccae5b39c2bf77e3531947f" alt="$a$"
data:image/s3,"s3://crabby-images/640a9/640a9d94fb084acda54f97fe5e241904fbc498ac" alt="$b$"
Calcul des coordonnées de data:image/s3,"s3://crabby-images/b7651/b76510a45f5229c41e77a7b1cb80f4223cad4986" alt="$M_2$"
Ensuite, data:image/s3,"s3://crabby-images/289d2/289d24a7a26e8a4175843d463d430ba862c5a553" alt="$M_1M_2=L$"
data:image/s3,"s3://crabby-images/eb31a/eb31a9fedcbff97c53aaf550633a8534165687fb" alt="M_1M_2=L
\iff
M_1M_2^2=L^2
\iff
\left( x_2-x_1\rp^2+\left( y_2-y_1\rp^2=L^2"
Or on a vu que
data:image/s3,"s3://crabby-images/b30e1/b30e137561f082f40969c862ff2d862c162837d7" alt="$y_2=ax_2+b$"
data:image/s3,"s3://crabby-images/1991b/1991bd27b68ace3f96650ccbdbcb276f27972eb5" alt="$M_1$"
data:image/s3,"s3://crabby-images/d179e/d179eba0836b9c342fbe4f8e2875bd53c127e392" alt="$(AB)$"
data:image/s3,"s3://crabby-images/5337f/5337f45b3652c05df91920b6b23b656077416273" alt="$y_1=ax_1+b$"
data:image/s3,"s3://crabby-images/53a57/53a57e15ccb2d4ea275fd1e7cd77c9d613f3c493" alt="$y_2-y_1=\lp ax_2+b\rp-\lp ax_1+b\rp=a\lp x_2-x_1\rp$"
![\begin{array}{ll}
M_1M_2=L
&\iff \left( x_2-x_1\rp^2+\left( y_2-y_1\rp^2=L^2 \\[1em]
&\iff \left( x_2-x_1\rp^2+a^2\left( x_2-x_1\rp^2=L^2\\[1em]
&\iff \left( x_2-x_1\rp^2\left(1+a^2\rp=L^2 \\[1em]
&\iff \left( x_2-x_1\rp^2=\dfrac{L^2}{1+a^2}
\enar](canvas-line-style-pointilles-dashed-IMG/55.png)
On tourve ainsi deux possibilités pour
data:image/s3,"s3://crabby-images/f0429/f04293be00265a9969ae38c83e2b720da3edce15" alt="$x_2$"
data:image/s3,"s3://crabby-images/0ae65/0ae65a07047fc66df9991d5a3272d23f002a2bd9" alt="x_2-x_1=\sqrt{\dfrac{L^2}{1+a^2}}=\dfrac{L}{\sqrt{1+a^2}}
\iff
x_2=x_1+\dfrac{L}{\sqrt{1+a^2}}"
ou
data:image/s3,"s3://crabby-images/f22e2/f22e2af41b698b0a2f83f486f26d400fdeba9541" alt="x_2-x_1=-\sqrt{\dfrac{L^2}{1+a^2}}
\iff
x_2=x_1-\dfrac{L}{\sqrt{1+a^2}}"
Ces deux valeurs sont les deux abscisses possibles pour
data:image/s3,"s3://crabby-images/faacd/faacd876c5ea859f19e6daa37f26afa9c2ea0176" alt="$M_2$"
data:image/s3,"s3://crabby-images/6a606/6a606264037b7f062bf912018184fb9c57a57e06" alt="\psset{unit=1.2cm,arrowsize=7pt}\begin{pspicture}(-1.5,-.4)(6.5,1.8)
\psline[linewidth=.3pt,linestyle=dashed"(6,1)
\rput(-1,.95){$\bullet$}\rput(-1,1.2){$A$}
\rput(1,.95){$\bullet$}\rput(1,1.2){$M_2$}
\rput(2,.95){$\bullet$}\rput(2,1.2){$M_1$}
\rput(3,.95){$\bullet$}\rput(3,1.2){$M_2$}
\rput(6,.95){$\bullet$}\rput(6,1.2){$B$}
\psline(1,1.1)(1,.1)\psline{<->}(1,.2)(2,.2)
\psline(2,1.1)(2,.1)\psline{<->}(3,.2)(2,.2)
\psline(3,1.1)(3,.1)
\rput(1.5,.4){$L$}\rput(2.5,.4){$L$}
\end{pspicture}](canvas-line-style-pointilles-dashed-IMG/60.png)
Il reste donc à choisir le point
![$M_2\in[M_1;B]$](canvas-line-style-pointilles-dashed-IMG/61.png)
data:image/s3,"s3://crabby-images/0428b/0428b1cc7a8733ba5a95cd2379b3836f0b3b9290" alt="$x_2$"
data:image/s3,"s3://crabby-images/3e1fa/3e1fa9e0ff0902d73bcc0979b320098b928d674c" alt="$x_B-x_A$"
- si
,
est à droite de
dans le canvas, et donc aussi
.
- si
, c'est le contraire.
En résumé, on a:
data:image/s3,"s3://crabby-images/657ba/657bad14181e0dd5e987ffc28e9f4343c6f271e3" alt="x_2=x_1+\mbox{signe}\left( x_B-x_A\rp\dfrac{L}{\sqrt{1+a^2}}"
et alors,
data:image/s3,"s3://crabby-images/d93d1/d93d148cbed3c0969703f324f9dbd6da12bfdee3" alt="$y_2=ax_2+b$"
Dernière chose: il faut que
![$M_2\in[M_1;B]$](canvas-line-style-pointilles-dashed-IMG/71.png)
data:image/s3,"s3://crabby-images/b27a9/b27a9c87992582b3c59dc5642e7d8ba45b72791e" alt="$B$"
data:image/s3,"s3://crabby-images/6856a/6856a203676918343c849836f83d66920a2972b7" alt="$M_1M_2>M_1B$"
data:image/s3,"s3://crabby-images/59273/592733b31327c47deef86d4344adc2debb34ed13" alt="$B$"
data:image/s3,"s3://crabby-images/e7e76/e7e760ac60f72b10f7ea34747906d1666ad2076d" alt="$M_2$"
data:image/s3,"s3://crabby-images/8e71e/8e71eb3712948a63cc19a2490da579aa9ae70930" alt="$B$"
Voir aussi: