Les différents formats d'images

Quand vous avez une image « entre les mains », vous avez la possibilité de l'enregistrer dans plusieurs « formats » différents. Le poids (en Ko, voire en Mo) de l'image sera plus ou moins élevé selon le format choisi et la qualité de l'image va changer.

Par exemple, le logiciel de dessin Paint (même si c'est loin d'être le meilleur) vous propose de choisir entre plusieurs formats lorsque vous enregistrez une image (figure suivante).

différents formats d'image paint
Différents formats d'image proposés par Paint

Certains formats sont plus adaptés que d'autres selon l'image (photo, dessin, image animée…). Notre but ici est de faire le tour des différents formats utilisés sur le Web pour que vous les connaissiez et sachiez choisir celui qui convient le mieux à votre image. Rassurez-vous, il n'y a pas beaucoup de formats différents, cela ne sera donc pas bien long.

Toutes les images diffusées sur Internet ont un point commun : elles sont compressées. Cela veut dire que l'ordinateur fait des calculs pour qu'elles soient moins lourdes et donc plus rapides à charger.

Haut

Le JPEG

Les images au format JPEG (Joint Photographic Expert Group) sont très répandues sur le Web. Ce format est conçu pour réduire le poids des photos (c'est-à-dire la taille du fichier associé), qui peuvent comporter plus de 16 millions de couleurs différentes. La figure suivante est une photo enregistrée au format JPEG.

photo montagne JPG
Une photo de montagne en JPEG

Les images JPEG sont enregistrées avec l'extension .jpg ou .jpeg.

Notez que le JPEG détériore un peu la qualité de l'image, d'une façon généralement imperceptible. C'est ce qui le rend si efficace pour réduire le poids des photos.
Quand il s'agit d'une photo, on ne peut généralement pas détecter la perte de qualité. Par contre, si ce n'est pas une photo, vous risquez de voir l'image un peu « baver ». Dans ce cas, il vaut mieux utiliser le format PNG.

Le PNG

Le format PNG (Portable Network Graphics) est le plus récent de tous. Ce format est adapté à la plupart des graphiques (je serais tenté de dire « à tout ce qui n'est pas une photo »). Le PNG a deux gros avantages : il peut être rendu transparent et il n'altère pas la qualité de l'image.

Le PNG a été inventé pour concurrencer un autre format, le GIF, à l'époque où il fallait payer des royalties pour pouvoir utiliser des GIF. Depuis, le PNG a bien évolué et c'est devenu le format le plus puissant pour enregistrer la plupart des images.

Le PNG existe en deux versions, en fonction du nombre de couleurs que doit comporter l'image:

  • PNG 8 bits: 256 couleurs;
  • PNG 24 bits: 16 millions de couleurs (autant qu'une image JPEG).

La figure suivante est une image PNG en 24 bits, représentant Zozor, qui sera notre mascotte tout au long de ce cours.

zozor png
Zozor en PNG

La compression du JPEG est plus puissante sur les photos. Une photo enregistrée en JPEG se chargera toujours beaucoup plus vite que si elle était enregistrée en PNG. Je vous conseille donc toujours de réserver le format JPEG aux photos.

Haut

Le GIF

C'est un format assez vieux, qui a été néanmoins très utilisé (et qui reste très utilisé par habitude). Aujourd'hui, le PNG est globalement bien meilleur que le GIF : les images sont généralement plus légères et la transparence est de meilleure qualité. Je vous recommande donc d'utiliser le PNG autant que possible.

Le format GIF est limité à 256 couleurs (alors que le PNG peut aller jusqu'à plusieurs millions de couleurs).

Néanmoins, le GIF conserve un certain avantage que le PNG n'a pas : il peut être animé. D'où l'explosion ces dernières années des GIF animés sur le web (aussi appelé "reaction gifs").

gif animé
Un GIF animé

Il existe un format adapté à chaque image

Si on résume, voici quel format adopter en fonction de l'image que vous avez:

  • Une photo: utilisez un JPEG.
  • N'importe quel graphique avec peu de couleurs (moins de 256): utilisez un PNG 8 bits ou éventuellement un GIF.
  • N'importe quel graphique avec beaucoup de couleurs: utilisez un PNG 24 bits.
  • Une image animée: utilisez un GIF animé.

Les erreurs à éviter

Bannissez les autres formats

Les autres formats non cités ici, comme le format BITMAP (*.bmp) sont à bannir car bien souvent ils ne sont pas compressés, donc trop gros. Ils ne sont pas du tout adaptés au Web. On peut en mettre sur son site mais le chargement sera vraiment extrêmement long !

Choisissez bien le nom de votre image

Si vous voulez éviter des problèmes, prenez l'habitude d'enregistrer vos fichiers avec des noms en minuscules, sans espace ni accent, par exemple: mon_image.png.

Vous pouvez remplacer les espaces par le caractère underscore (« _ ») comme je l'ai fait ici.

Haut


Insérer une image

Insertion d'une image

Quelle est la fameuse balise qui va nous permettre d'insérer une image ? Il s'agit de… <img /> !

C'est une balise de type orpheline (comme <br />). Cela veut dire qu'on n'a pas besoin de l'écrire en deux exemplaires comme la plupart des autres balises que nous avons vues jusqu'ici. En effet, nous n'avons pas besoin de délimiter une portion de texte, nous voulons juste insérer une image à un endroit précis.

La balise doit être accompagnée de deux attributs obligatoires:

  • src: il permet d'indiquer où se trouve l'image que l'on veut insérer. Vous pouvez soit mettre un chemin absolu (ex.: http://www.site.com/fleur.png), soit mettre le chemin en relatif (ce qu'on fait le plus souvent).
    Ainsi, si votre image est dans un sous-dossier images, vous devrez taper: src="images/fleur.png"

  • alt: cela signifie « texte alternatif ». On doit toujours indiquer un texte alternatif à l'image, c'est-à-dire un court texte qui décrit ce que contient l'image.
    Ce texte sera affiché à la place de l'image si celle-ci ne peut pas être téléchargée (cela arrive), ou dans les navigateurs de personnes handicapées (non-voyants) qui ne peuvent malheureusement pas « voir » l'image. Cela aide aussi les robots des moteurs de recherche pour les recherches d'images.
    Pour la fleur, on mettrait par exemple: alt="Une fleur".

Les images doivent se trouver obligatoirement à l'intérieur d'un paragraphe (<p> </p>). Voici un exemple d'insertion d'image:

                            1   <p>
2       Voici une photo que j'ai prise lors de mes dernières vacances à la montagne : <br />
3       <img src="images/montagne.jpg" alt="Photo de montagne" />
4   </p>
                        

Bref, l'insertion d'image est quelque chose de très facile pour peu qu'on sache indiquer où se trouve l'image, comme on avait appris à le faire avec les liens.
La plus grosse « difficulté » (si on peut appeler cela une difficulté) consiste à choisir le bon format d'image. Ici, c'est une photo donc c'est évidemment le format JPEG qu'on utilise.

Attention!! Je le répète : évitez à tout prix les accents, majuscules et espaces dans vos noms de fichiers et de dossiers. Voici un chemin qui va poser problème: "Images du site/Image toute bête.jpg".
Il faudrait supprimer les espaces (ou les remplacer par le symbole « _ »), supprimer les accents et tout mettre en minuscules comme ceci: "images_du_site/image_toute_bete.jpg".
Sachez donc que, si votre image ne s'affiche pas, c'est très certainement parce que le chemin est incorrect ! Simplifiez au maximum vos noms de fichiers et de dossiers, et tout ira bien.

Haut

Ajouter une infobulle

L'attribut permettant d'afficher une bulle d'aide est le même que pour les liens: il s'agit de title. Cet attribut est facultatif (contrairement à alt).

Voici ce que cela peut donner:

                            1   <p>
2       Voici une photo que j'ai prise lors de mes dernières vacances à la montagne : <br />
3       <img src="images/montagne.jpg" alt="Photo de montagne" title="C'est beau les Alpes quand même !" />
4   </p>
                        

Il faut survoler la photo avec la souris pour voir l'infobulle apparaître.

Haut

Miniature cliquable

Si votre image est très grosse, il est conseillé d'en afficher la miniature sur votre site. Ajoutez ensuite un lien sur cette miniature pour que vos visiteurs puissent afficher l'image en taille originale.

De nombreux sites permettent de redimensionner des images, comme ResizeImage.net par exemple. Je vais ainsi disposer de deux versions de ma photo, comme à la figure suivante): la miniature et l'image d'origine.

miniature + image d'origine
La miniature et son image d'origine

Je les place toutes les deux dans un dossier appelé par exemple img. J'affiche la version montagne_mini.jpg sur ma page et je fais un lien vers montagne.jpg pour que l'image agrandie s'affiche lorsqu'on clique sur la miniature.

Voici le code HTML que je vais utiliser pour cela:

                            1   <p>
2       Vous souhaitez voir l'image dans sa taille d'origine ? Cliquez dessus ! <br />
3       <a href="img/montagne.jpg"><img src="images/montagne.jpg" alt="Photo de montagne" title="Cliquez pour agrandir" /></a>
4   </p>
                        

À savoir!! Parfois, certains navigateurs choisissent d'afficher un cadre bleu (ou violet) pas très esthétique autour de votre image cliquable.
Heureusement, nous pourrons retirer ce cadre dans peu de temps grâce au CSS.

Haut


Les figures

Au cours de la lecture de ce livre, vous avez déjà rencontré plusieurs fois des figures. Ce sont des éléments qui viennent enrichir le texte pour compléter les informations de la page.

Les figures peuvent être de différents types:

  • images;
  • codes source;
  • citations;
  • etc...

Bref, tout ce qui vient illustrer le texte est une figure. Nous allons ici nous intéresser aux images mais, contrairement à ce qu'on pourrait croire, les figures ne sont pas forcément des images: un code source aussi illustre le texte.

Création d'une figure

Reprenons par exemple cette capture d'écran du premier chapitre, représentée à la figure suivante.

logiciel bloc-notes
Le logiciel Bloc-Notes

En HTML5, on dispose de la balise <figure>. Voici comment on pourrait l'utiliser:

                            1   <figure>
2       <img src="images/blocnotes.png" alt="Bloc-Notes"  />
3   </figure>
                        

Une figure est le plus souvent accompagnée d'une légende. Pour ajouter une légende, utilisez la balise <figcaption> à l'intérieur de la balise <figure>, comme ceci:

                            1   <figure>
2       <img src="images/blocnotes.png" alt="Bloc-Notes"  />
3       <figcaption>Le logiciel Bloc-Notes</figcaption>
4   </figure>
                        

Haut

Bien comprendre le rôle des figures

Un peu plus tôt dans ce chapitre, je vous ai dit que les images devaient être situées dans des paragraphes (placées à l'intérieur d'une balise <p> </p>). Ce n'est pas tout à fait vrai.

Si vous faites de votre image une figure, l'image peut être située en-dehors d'un paragraphe.

                            1   <p>Connaissez-vous le logiciel Bloc-Notes ? On peut faire des sites web avec !</p>
2   
3   <figure>
4       <img src="images/blocnotes.png" alt="Bloc-Notes"  />
5       <figcaption>Le logiciel Bloc-Notes</figcaption>
6   </figure>
                        

Quand dois-je placer mon image dans un paragraphe et quand dois-je la placer dans une figure ?
Bonne question ! Tout dépend de ce que votre image apporte au texte:

  • Si elle n'apporte aucune information (c'est juste une illustration pour décorer): placez l'image dans un paragraphe.
  • Si elle apporte une information: placez l'image dans une figure.

La balise <figure> a un rôle avant tout sémantique. Cela veut dire qu'elle indique à l'ordinateur que l'image a du sens et qu'elle est importante pour la bonne compréhension du texte. Cela peut permettre à un programme de récupérer toutes les figures du texte et de les référencer dans une table des figures, par exemple.

Enfin, sachez qu'une figure peut très bien comporter plusieurs images. Voici un cas où cela se justifie:

                            1   <figure>
2       <img src="images/internetexplorer.png" alt="Logo Internet Explorer"  />
3       <img src="images/firefox.png" alt="Logo Mozilla Firefox"  />
4       <img src="images/chrome.png" alt="Logo Google Chrome"  />
5       <figcaption>Logos des différents navigateurs</figcaption>
6   </figure>
                        

Haut