Codage informatique des couleursLe codage informatique des couleurs est l'ensemble des conventions permettant l'affichage ou l'impression par un périphérique informatique d'une image en couleurs, plutôt qu'en noir et blanc. Le codage se base sur la synthèse additive trichrome des couleurs. Au niveau du périphérique, l'image est toujours matricielle. On définit, pour chaque pixel, un triplet de valeurs (rouge, vert, bleu). Les fichiers peuvent enregistrer l'image sous forme d'un tableau de ces valeurs, éventuellement comprimé, ou bien sous forme vectorielle, c'est-à-dire sous forme d'instructions permettant de reconstituer une image matricielle. L'utilisateur, dans les programmes d'édition d'images, peut également définir la couleur par les paramètres dérivés (teinte, saturation, lumière). PrincipesIl y a lieu de se demander quelle est la quantité d'information nécessaire à l'affichage de la couleur. Dans le meilleur des cas, on peut distinguer quelques dizaines de niveaux de gris. Le codage sur un octet permet 256 niveaux ; il est pratique et on est sûr qu'il faudra plus d'un écart de un pour obtenir des gris visuellement différents. Avec un demi-octet, on n'aurait que 16 nuances, ce n'est pas assez ; un nombre de bits intermédiaire entre 4 et 8 complique toutes les opérations. Les mêmes raisons s'appliquant à chaque canal de couleur primaire (rouge, vert, bleu), on peut leur attribuer chacun un octet. Avec un octet pour chaque canal, on obtient plus de 16 millions de codes de couleur. Une estimation grossière des capacités à distinguer les couleurs donne environ 15 à 20 000 nuances identifiables ; en prenant comme référence le seuil de discrimination des couleurs, on arrive, dans les meilleures conditions d'examen, à un demi-million de couleurs[1]. Parmi ces couleurs, une partie se trouve hors du gamut des écrans et imprimantes ; mais la grandeur du seuil de discrimination, exprimée en grandeur des composantes (rouge, vert, bleu), n'est pas répartie uniformément parmi les couleurs, de sorte qu'une division de l'étendue des valeurs par le nombre des couleurs qu'on peut distinguer ne serait pas adéquate. D'autre part, entre le code et l'affichage, les valeurs représentant la couleur vont être multipliées par plusieurs coefficients, permettant d'assurer que le blanc du code produit du blanc et que les gris sont neutres et correctement répartis. Ces réglages du contraste et du gamma se font en arrière-plan, soit dans l'ordinateur, soit dans le périphérique. En codant plus de trente fois plus de couleurs que ce que l'œil distingue, on peut cependant être sûr d'avoir suffisamment d'information, pour que deux codes qui ne diffèrent que de 1 ou 2 sur les 256 valeurs possibles de chaque canal donnent une couleur parfaitement indistincte. Nombre de bits par pixelLes anciens modes graphiques VESA 10Eh, 111h, 114h, 117h et 11Ah utilisés notamment sous MS-DOS effectuent le codage RVB d'un pixel sur 16 bits[2]. Les bits 0 à 4 donnent 32 valeurs de bleu, ceux de 5 à 10, 64 niveaux de vert, élément principal de la luminance, et ceux 11 à 15 codent 32 valeurs de rouge[3]. La plupart des ordinateurs permettent encore l'utilisation de ce mode d'affichage quand la carte graphique le permet. Ce nombre de bits aboutit à 65 536 couleurs, pas tout à fait assez pour que la transition entre deux couleurs voisines soit toujours insensible, particulièrement avec des réglages d'écran contrastés pour favoriser la lecture du texte. En outre, le système doit séparer des valeurs qui ne sont pas des octets. Quand les performances des ordinateurs se sont améliorées, les fabricants sont passés au codage de la couleur à un octet par canal, soit 24 bits. PalettesQuand la puissance des ordinateurs (anciens) ou le débit du canal de transmission (Web) limite la taille des fichiers, une table de correspondance appelée, par analogie avec celle des peintres, palette permet d'enregistrer les couleurs sur 8 bits, qui sont les index d'un tableau qui leur fait correspondre 256 valeurs R, V, B. Ce procédé divise par 3 la taille du fichier d'une image non compressée. Les logiciels graphiques peuvent calculer la palette optimale pour une image et l'annexer à cette image. La taille de la palette, 768 octets (3 fois 256), est souvent négligeable. Les logiciels calculent aussi le rendu des couleurs intermédiaires par tramage. Les ordinateurs proposaient aussi une palette par défaut. Cette palette n'était pas normalisée. Il existait toutefois un certain consensus lié à l'existence d'une sorte de standard HTML qui veut qu'une certaine palette dite « palette web » (en anglais « safe-web palette » ou « safety palette ») devait être privilégiée : dans les faits, la quasi-totalité des navigateurs Web respectait cette palette dont les trois composantes RVB peuvent être l'un des 6 multiples de 51 suivants : 0, 51, 102, 153, 204 ou 255, donnant 6 × 6 × 6, soit 216 couleurs. Les fichiers HTML peuvent appeler les couleurs de cette palette par un nom conventionnel, en anglais. La palette, quelle qu'elle soit, se présente généralement à l'utilisateur sous la forme d'un carrelage de couleurs. Compression des couleursLes procédés qui visent à réduire, avec le minimum de perte de qualité, la taille des fichiers, ne conservent évidemment pas les 24 bits par pixel, alors que 18 bits suffisent pour coder le demi-million de couleurs qu'un observateur puisse distinguer dans les meilleures conditions. Pour arriver à cette réduction, les logiciels procèdent comme on le fait en télévision en couleurs. Ils convertissent le triplet (rouge, vert, bleu) en un triplet (luminance, différence bleu, différence rouge)[4], avec l'espace de couleurs YCbCr. Huit bits codent la luminance ; avec huit autres bits pour la chrominance, quatre pour chaque canal, on atteint 65 536 couleurs, plus que l'estimation du nombre de couleurs identifiables. Des matrices de transformation et des tables de correspondance permettent d'affiner la correspondance entre les couleurs et la sensibilité visuelle aux différences de couleur. Pour la compression JPEG, la valeur de luminance est transmise intégralement aux modules de compression ; la chrominance, qui agglomère les deux valeurs de différence de couleur, est sous-échantillonnée ; elle peut aussi être quantifiée, réduisant le nombre de couleurs codées. Codage perceptuelDans les logiciels d'édition d'image matricielle ou d'image vectorielle, l'utilisateur est amené à choisir et à modifier des couleurs. Il peut pointer une nuance dans un dégradé, changer la position d'un curseur, introduire une valeur numérique. Dans tous les cas, l'écran, surface plane, a deux dimensions, alors que la couleur a trois paramètres. Dès les débuts de l'affichage couleur, on a reconnu que le choix des couleurs se faisait plus facilement dans un espace de couleur organisé par les grandeurs de la perception des couleurs, teinte, saturation et luminosité, que dans le cube des valeurs (rouge, vert, bleu). Il en existe principalement deux variantes, TSV et TSL. Les valeurs de teinte, de saturation et de luminosité ou valeur se donnent en nombres décimaux, ce qui permet une conversion exacte et réversible avec les valeurs (rouge, vert, bleu) en nombres entiers sur un octet. Les fichiers d'image vectorielle, comme Scalable Vector Graphics (SVG), admettent ces définitions de couleurs, au même titre que les autres objets graphiques. Il en va de même pour les feuilles de style en cascade ((en) Cascading Style Sheets, CSS) de présentation des pages HTML et documents écrits. TransparenceL'intérêt de coder les couleurs sur 24 bits est assez modéré quand les ordinateurs traitent des bytes de 16 bits. Il reste un octet inutilisé. Dans les logiciels d'édition d'image, il est souvent intéressant de travailler séparément des images et des fonds, à l'image des cellulos du dessin animé. Pour que ce soit possible, il faut indiquer, à chaque pixel, la transparence. On a pu indiquer, avec seulement un bit, si la couche (ou calque) était transparent ou opaque. L'attribution d'une valeur de transparence, sur un octet, permet tous les mélanges. Cette valeur est généralement appelée α (alpha). Le rendu d'un pixel s'obtient par multiplication et addition, récursive, des valeurs des couches. Pour chaque composante (rouge, vert, bleu), la valeur rendue est égale à la valeur de la couche supérieure, multipliée par (1 - α) plus la valeur du rendu des couches inférieures, multipliée par α[5]. L'augmentation de la puissance de calcul des ordinateurs a rendu possible la combinaison de plusieurs images, transmises séparément. De cette manière, on peut transmettre une seule fois un fond, puis lui ajouter une partie mobile. Le canal alpha est inclus dans HTML 4 et MPEG 4 pour les images vidéo[6] DétailsLe codage d'un pixel peut se faire sur 32 bits, dont 24 bits sont utilisés pour coder la couleur, les 8 bits restants étant :
Dans la première partie de l'article, nous ne nous intéresserons qu'aux 24 bits de codage des couleurs. Les explications données correspondront donc non seulement à la représentation des couleurs sur 32 bits mais aussi à celle sur 24 bits. Les 24 bits d'une couleur se décomposent en 3 fois 8 bits :
Une séquence de 8 bits permet de coder un nombre entier compris entre 0 et Vmax = 255 : en effet, 28 vaut 256. Par conséquent, la valeur de la composante rouge d'un pixel peut être représentée selon 256 niveaux différents (allant du 0, absence de rouge, à 255, rouge d'intensité maximum). Et il en est de même pour les 2 autres composantes primaires, le vert et le bleu. Exemple :
111110111101000010010111. Il existe deux grandes familles de représentation des couleurs, telles qu'elles peuvent apparaître dans une image présentée sur un écran d'ordinateur : le codage trichrome RVB (ou RGB en anglais), dont les principes viennent d'être décrits, et le codage perceptuel Teinte saturation lumière (ou HSL en anglais) basé sur les classements artistiques et psychophysiques des perceptions des couleurs. Le codage RVB correspond aux moyens physiques pour produire de la couleur dans les périphériques informatiques : en entrée (scanner-couleurs, appareil photo numérique, caméscope…) comme en sortie (écran en couleurs, imprimante, quadrichromie, photocopieuse-couleurs…). Le codage TSL, destiné aux opérateurs humains, est adapté à la caractéristique de leur vision. Les modèles de description TSL présentent des paramètres simplifiés, adaptés au codage informatique des couleurs, et permettant de convertir rapidement RVB en TSL et retour. Exemple :
Voyons donc à présent quelles sont les valeurs des 3 composantes du codage TSL (HSL), un des codages du groupe perceptuel, de la couleur choisie précédemment, exprimées (comme c'est assez souvent le cas[réf. souhaitée]) selon une échelle allant de 0 à 240 :
Outils de sélection de couleurUn outil de sélection de couleur comporte en général au minimum 4 parties :
Pour comprendre comment fonctionne un sélecteur de couleurs, il est commode de se représenter l'ensemble des couleurs disponibles sous la forme suivante :
Le choix d'une couleur consiste donc à définir un point situé à l'intérieur de (ou sur) ce cône des couleurs. Dans tous les cas, la définition d'une couleur par ses composantes Teinte saturation luminosité exige un triple choix qui doit nécessairement être réalisé par l'opérateur en 2 temps :
Dégradé de teintesDans le calcul de dégradés de couleurs, le choix des grandeurs qu'on va interpoler pour calculer les couleurs intermédiaires change considérablement le rendu, dès lors que les couleurs ont des teintes différentes. La variation la plus évidente se voit dans le dégradé entre couleurs complémentaires :
Voir aussiBibliographieArticles connexesLiens externesNotes et références
|