« ANSI » : différence entre les versions
(ANSI rainbow) |
m (→En perl) |
||
(4 versions intermédiaires par le même utilisateur non affichées) | |||
Ligne 108 : | Ligne 108 : | ||
|Reset ''or'' normal | |Reset ''or'' normal | ||
|All attributes become turned off | |All attributes become turned off | ||
|[[Fichier:ANSO0M.png|sans_cadre]] | |[[Fichier:ANSO0M.png|sans_cadre]] | ||
|- | |- | ||
|1 | |1 | ||
Ligne 275 : | Ligne 275 : | ||
Comme quoi dans un terminal en mode caractère on peut faire de jolie dessins! | Comme quoi dans un terminal en mode caractère on peut faire de jolie dessins! | ||
== Utiliser dans du code == | |||
L'utilisation des codes ANSI dans un programme peut se faire en incluant simplement les codes d’échappement dans les chaines de caractères écrites à l'écran. | |||
Ainsi pour écrire! | |||
[[Fichier:ANSI example.png|sans_cadre|180x180px]] | |||
On utilisera la chaine :<syntaxhighlight lang="bash"> | |||
"Hello \033[7m world \033[0m !" | |||
</syntaxhighlight> | |||
=== En shell === | |||
Attention en bash ou tout descendant du bourne shell un simple:<syntaxhighlight lang="bash"> | |||
echo "Hello \033[7m world \033[0m !" | |||
</syntaxhighlight>Donnera ...<syntaxhighlight lang="text"> | |||
Hello \033[7m world \033[0m ! | |||
</syntaxhighlight>Il faut préciser l'option -e (enambble escape characters) <syntaxhighlight lang="bash"> | |||
echo -e "Hello \033[7m world \033[0m !" | |||
</syntaxhighlight>Ou (seulement en bash) la commande printf dont la syntaxes est celle du C.<syntaxhighlight lang="bash"> | |||
printf "Hello \033[7m world \033[0m !\n" | |||
</syntaxhighlight> | |||
=== En C/C++ === | |||
<syntaxhighlight lang="c++"> | |||
void main(int argc, char** argv){ | |||
printf ("Hello \033[7m world \033[0m !\n"); | |||
} | |||
</syntaxhighlight> | |||
=== En perl === | |||
On peut faire simplement :<syntaxhighlight lang="perl"> | |||
print "Hello \033[7m world \033[0m !\n"; | |||
</syntaxhighlight>[[Fichier:HelloWorld-ANSIPL.png|sans_cadre|147x147px]] | |||
Mais on peut utiliser la module Term::ANSIColor | |||
Il y a pas mal de façon de l'utiliser. La plus simple : | |||
<syntaxhighlight lang="perl"> | |||
use Term::ANSIColor qw(:constants); | |||
print "[".GREEN."PASS".RESET."]\n"; | |||
print "[".RED."FAIL".RESET."]\n"; | |||
</syntaxhighlight> | |||
[[Fichier:PASSFAIL-ANSI-PL.png|sans_cadre|109x109px]] | |||
Les constantes utilisables: | |||
<syntaxhighlight lang="text"> | |||
CLEAR RESET BOLD DARK | |||
FAINT ITALIC UNDERLINE UNDERSCORE | |||
BLINK REVERSE CONCEALED | |||
BLACK RED GREEN YELLOW | |||
BLUE MAGENTA CYAN WHITE | |||
BRIGHT_BLACK BRIGHT_RED BRIGHT_GREEN BRIGHT_YELLOW | |||
BRIGHT_BLUE BRIGHT_MAGENTA BRIGHT_CYAN BRIGHT_WHITE | |||
ON_BLACK ON_RED ON_GREEN ON_YELLOW | |||
ON_BLUE ON_MAGENTA ON_CYAN ON_WHITE | |||
ON_BRIGHT_BLACK ON_BRIGHT_RED ON_BRIGHT_GREEN ON_BRIGHT_YELLOW | |||
ON_BRIGHT_BLUE ON_BRIGHT_MAGENTA ON_BRIGHT_CYAN ON_BRIGHT_WHITE | |||
</syntaxhighlight>On se limite aux couleurs mais le module permet beaucoup de choses. Une description en français est disponible sur [https://perldoc.perl.org/Term::ANSIColor la page du module] lui même. | |||
=== En java === | |||
<syntaxhighlight lang="java"> | |||
class HelloWorld { | |||
public static void main(String[] args) { | |||
System.out.println("Hello \033[7m world \033[0m !"); | |||
} | |||
} | |||
</syntaxhighlight>Bon au retour à la ligne près (certaint l'incluent par défaut d'autres pas) c'est toujours la même chaine. | |||
Un langage fait le malin pour pas faire comme les autres python | |||
=== En python === | |||
Un simple <syntaxhighlight lang="python3"> | |||
print ("Hello \033[7m world \033[0m !") | |||
</syntaxhighlight>Affiche: | |||
[[Fichier:Python ANSI wrong.png|sans_cadre]] | |||
Il interprète (un peu) les codes ANSI pour les remplacer par... des espaces. Etrange. | |||
Pour utiliser les codes ANSI il faut utiliser une autre syntaxe et, de plus, seul les changements de couleurs (3x pour la couleur du texte et 4x pour le fond) sont acceptés.<syntaxhighlight lang="python"> | |||
print (u"Hello \u001B[47m\u001B[30m World \u001B[0m !") | |||
</syntaxhighlight>Nous donne "presque" ce que nous attendons. | |||
[[Fichier:Python-Hello-almost-perfect.png|sans_cadre|156x156px]] | |||
Le "World" est écrit en noir sur fond ''blanc sale''. en Gris quoi. | |||
N'essayez pas de remplacer \001B[47m par \001B[107m ça ne marches pas. | |||
Python a "sa syntaxe":<syntaxhighlight lang="python"> | |||
print (u"\nHello \u001B[47;1m\u001B[30m World \u001B[0m !") | |||
</syntaxhighlight>Le ;1 après le \u001B[47 et le m dit que la couleur doit être "vive". | |||
Un nombre limité de fonctions de gestion de curseur sont aussi gérées: | |||
---- | |||
* '''Up''': <code>\u001b[{n}A</code> moves cursor up by <code>n</code> | |||
* '''Down''': <code>\u001b[{n}B</code> moves cursor down by <code>n</code> | |||
* '''Right''': <code>\u001b[{n}C</code> moves cursor right by <code>n</code> | |||
* '''Left''': <code>\u001b[{n}D</code> moves cursor left by <code>n</code> | |||
---- | |||
* '''Next Line''': <code>\u001b[{n}E</code> moves cursor to beginning of line <code>n</code> lines down | |||
* '''Prev Line''': <code>\u001b[{n}F</code> moves cursor to beginning of line <code>n</code> lines down | |||
---- | |||
* '''Set Column''': <code>\u001b[{n}G</code> moves cursor to column <code>n</code> | |||
* '''Set Position''': <code>\u001b[{n};{m}H</code> moves cursor to row <code>n</code> column <code>m</code> | |||
---- | |||
* '''Clear Screen''': <code>\u001b[{n}J</code> clears the screen | |||
** <code>n=0</code> clears from cursor until end of screen, | |||
** <code>n=1</code> clears from cursor to beginning of screen | |||
** <code>n=2</code> clears entire screen | |||
* '''Clear Line''': <code>\u001b[{n}K</code> clears the current line | |||
** <code>n=0</code> clears from cursor to end of line | |||
** <code>n=1</code> clears from cursor to start of line | |||
** <code>n=2</code> clears entire line | |||
---- | |||
* '''Save Position''': <code>\u001b[{s}</code> saves the current cursor position | |||
* '''Save Position''': <code>\u001b[{u}</code> restores the cursor to the last saved position | |||
Ces infos ont été trouvées sur : https://www.lihaoyi.com/post/BuildyourownCommandLinewithANSIescapecodes.html | |||
En Python ce qui est compliqué devient très simple (numpy par exemple permet de gérer des matrices de réels en deux lignes de code) mais ce qui était simple (écrite en inversion vidéo) devient très compliqué! |
Version actuelle datée du 2 mars 2024 à 16:59
Les codes d'échappement
Code | Abbr | Name | Effect |
---|---|---|---|
CSI n A | CUU | Cursor Up | Moves the cursor n (default 1 ) cells in the given direction. If the cursor is already at the edge of the screen, this has no effect.
|
CSI n B | CUD | Cursor Down | |
CSI n C | CUF | Cursor Forward | |
CSI n D | CUB | Cursor Back | |
CSI n E | CNL | Cursor Next Line | Moves cursor to beginning of the line n (default 1 ) lines down. (not ANSI.SYS)
|
CSI n F | CPL | Cursor Previous Line | Moves cursor to beginning of the line n (default 1 ) lines up. (not ANSI.SYS)
|
CSI n G | CHA | Cursor Horizontal Absolute | Moves the cursor to column n (default 1 ). (not ANSI.SYS)
|
CSI n ; m H | CUP | Cursor Position | Moves the cursor to row n, column m. The values are 1-based, and default to 1 (top left corner) if omitted. A sequence such as CSI ;5H is a synonym for CSI 1;5H as well as CSI 17;H is the same as CSI 17H and CSI 17;1H
|
CSI n J | ED | Erase in Display | Clears part of the screen. If n is 0 (or missing), clear from cursor to end of screen. If n is 1 , clear from cursor to beginning of the screen. If n is 2 , clear entire screen (and moves cursor to upper left on DOS ANSI.SYS). If n is 3 , clear entire screen and delete all lines saved in the scrollback buffer (this feature was added for xterm and is supported by other terminal applications).
|
CSI n K | EL | Erase in Line | Erases part of the line. If n is 0 (or missing), clear from cursor to the end of the line. If n is 1 , clear from cursor to beginning of the line. If n is 2 , clear entire line. Cursor position does not change.
|
CSI n S | SU | Scroll Up | Scroll whole page up by n (default 1 ) lines. New lines are added at the bottom. (not ANSI.SYS)
|
CSI n T | SD | Scroll Down | Scroll whole page down by n (default 1 ) lines. New lines are added at the top. (not ANSI.SYS)
|
CSI n ; m f | HVP | Horizontal Vertical Position | Same as CUP, but counts as a format effector function (like CR or LF) rather than an editor function (like CUD or CNL). This can lead to different handling in certain terminal modes. |
CSI n m | SGR | Select Graphic Rendition | Sets colors and style of the characters following this code |
CSI 5i | AUX Port On | Enable aux serial port usually for local serial printer | |
CSI 4i | AUX Port Off | Disable aux serial port usually for local serial printer | |
CSI 6n | DSR | Device Status Report | Reports the cursor position (CPR) by transmitting ESC[n;mR , where n is the row and m is the column.
|
Les styles
Il s'agit de détailler les codes :
CSI n m | SGR | Select Graphic Rendition | Sets colors and style of the characters following this code |
Le tableau suivant donne les modes existants:
* Les exemples sont pris sut putty/mobaxterm. N/A c'est que, sur les terminaux caractère standards ce code est sans effet.
Les couleurs
Couleurs de bases
On à 8 couleurs de bases + les mêmes couleurs en surintensité. (à la CGApour ceux qui s'en souviennent)
30–37 | Set foreground color | |
90-97 | Set bright foreground color | |
40–47 | Set background color | |
100-107 | Set bright background color |
Couleurs étendues
Là on passe aux écrans EGA, On agrandie la palette:
Le nombre indique la couleur de fond :
ESC[48:5:⟨n⟩m Select background color
La couleur du texte est soit blanc soit noir pour qu'on puise le voir. Pour changer la couleur du texte on peut, de la même façon,
ESC[38:5:⟨n⟩m Select foreground color
Attention avec putty, cygwin et donc mobaxterm, par défaut, ces subtilités ne sont pas gérées. En revanche le terminal de base linux sur raspberry PI et MINGW64 sous Windows marche tres bien.
#!/usr/bin/perl
my $c=0;
for ($i=16; $i<=231; $i++) {
printf "\033[48:5:%3sm ", $i;
$c++;
if (($c % 36)==0){
print ("\n");
}
}
Nous donne:
En 24 bits
On passe au VGA. 8 bits par composantes r, g et b. 8x3=24 bits. Ca fait quelque chose comme 17 million de couleurs différentes (16 777 216 exactement).
#!/usr/bin/perl
#
for ($y=0; $y<=255; $y+=4){
for ($x=0; $x<=255; $x+=2){
printf ("\033[48;2;%s;%s;%sm ",$x,$y,255-$x);
}
print ("\033[0m\n");
}
Nous donne un joli:
Comme quoi dans un terminal en mode caractère on peut faire de jolie dessins!
Utiliser dans du code
L'utilisation des codes ANSI dans un programme peut se faire en incluant simplement les codes d’échappement dans les chaines de caractères écrites à l'écran.
Ainsi pour écrire!
On utilisera la chaine :
"Hello \033[7m world \033[0m !"
En shell
Attention en bash ou tout descendant du bourne shell un simple:
echo "Hello \033[7m world \033[0m !"
Donnera ...
Hello \033[7m world \033[0m !
Il faut préciser l'option -e (enambble escape characters)
echo -e "Hello \033[7m world \033[0m !"
Ou (seulement en bash) la commande printf dont la syntaxes est celle du C.
printf "Hello \033[7m world \033[0m !\n"
En C/C++
void main(int argc, char** argv){
printf ("Hello \033[7m world \033[0m !\n");
}
En perl
On peut faire simplement :
print "Hello \033[7m world \033[0m !\n";
Mais on peut utiliser la module Term::ANSIColor
Il y a pas mal de façon de l'utiliser. La plus simple :
use Term::ANSIColor qw(:constants);
print "[".GREEN."PASS".RESET."]\n";
print "[".RED."FAIL".RESET."]\n";
Les constantes utilisables:
CLEAR RESET BOLD DARK
FAINT ITALIC UNDERLINE UNDERSCORE
BLINK REVERSE CONCEALED
BLACK RED GREEN YELLOW
BLUE MAGENTA CYAN WHITE
BRIGHT_BLACK BRIGHT_RED BRIGHT_GREEN BRIGHT_YELLOW
BRIGHT_BLUE BRIGHT_MAGENTA BRIGHT_CYAN BRIGHT_WHITE
ON_BLACK ON_RED ON_GREEN ON_YELLOW
ON_BLUE ON_MAGENTA ON_CYAN ON_WHITE
ON_BRIGHT_BLACK ON_BRIGHT_RED ON_BRIGHT_GREEN ON_BRIGHT_YELLOW
ON_BRIGHT_BLUE ON_BRIGHT_MAGENTA ON_BRIGHT_CYAN ON_BRIGHT_WHITE
On se limite aux couleurs mais le module permet beaucoup de choses. Une description en français est disponible sur la page du module lui même.
En java
class HelloWorld {
public static void main(String[] args) {
System.out.println("Hello \033[7m world \033[0m !");
}
}
Bon au retour à la ligne près (certaint l'incluent par défaut d'autres pas) c'est toujours la même chaine.
Un langage fait le malin pour pas faire comme les autres python
En python
Un simple
print ("Hello \033[7m world \033[0m !")
Affiche:
Il interprète (un peu) les codes ANSI pour les remplacer par... des espaces. Etrange.
Pour utiliser les codes ANSI il faut utiliser une autre syntaxe et, de plus, seul les changements de couleurs (3x pour la couleur du texte et 4x pour le fond) sont acceptés.
print (u"Hello \u001B[47m\u001B[30m World \u001B[0m !")
Nous donne "presque" ce que nous attendons.
Le "World" est écrit en noir sur fond blanc sale. en Gris quoi.
N'essayez pas de remplacer \001B[47m par \001B[107m ça ne marches pas.
Python a "sa syntaxe":
print (u"\nHello \u001B[47;1m\u001B[30m World \u001B[0m !")
Le ;1 après le \u001B[47 et le m dit que la couleur doit être "vive".
Un nombre limité de fonctions de gestion de curseur sont aussi gérées:
- Up:
\u001b[{n}A
moves cursor up byn
- Down:
\u001b[{n}B
moves cursor down byn
- Right:
\u001b[{n}C
moves cursor right byn
- Left:
\u001b[{n}D
moves cursor left byn
- Next Line:
\u001b[{n}E
moves cursor to beginning of linen
lines down - Prev Line:
\u001b[{n}F
moves cursor to beginning of linen
lines down
- Set Column:
\u001b[{n}G
moves cursor to columnn
- Set Position:
\u001b[{n};{m}H
moves cursor to rown
columnm
- Clear Screen:
\u001b[{n}J
clears the screenn=0
clears from cursor until end of screen,n=1
clears from cursor to beginning of screenn=2
clears entire screen
- Clear Line:
\u001b[{n}K
clears the current linen=0
clears from cursor to end of linen=1
clears from cursor to start of linen=2
clears entire line
- Save Position:
\u001b[{s}
saves the current cursor position - Save Position:
\u001b[{u}
restores the cursor to the last saved position
Ces infos ont été trouvées sur : https://www.lihaoyi.com/post/BuildyourownCommandLinewithANSIescapecodes.html
En Python ce qui est compliqué devient très simple (numpy par exemple permet de gérer des matrices de réels en deux lignes de code) mais ce qui était simple (écrite en inversion vidéo) devient très compliqué!