Réaliser une icône ou un logo en CSS3

Réaliser une icône ou un logo en CSS3

Langage : HTML, CSS3

Difficulté : Intermédiaire

Temps estimé : 5h

Télécharger les fichiers sources
Vous devez être logués ou enregistrés pour télécharger !

Salut à  tous, aujourd’hui je suis ici pour la rédaction d’un tutoriel sur la réalisation d’image en CSS3. Vous en avez sûrement déjà  entendu parler, soit via Twitter si vous me followez, soit en ayant parcouru le web, en effet plusieurs créations du type ont déjà  été postées sur le web comme par exemple le fail whale ou encore le logo opera.

Lorsque j’ai découvert ces réalisations, j’ai été assez impressionné de la qualité de ce travail et j’ai voulu me lancer moi aussi, mais je me suis rapidement trouvé face au mur. En effet, il n’existait, à  l’époque, pas de tutoriels expliquant les techniques de programmation utilisées. Du coup j’ai fait des recherches, accumulé des connaissances et je suis là  pour les partager.

Bon fini de blablater, je vais vous énoncer les points qui vont être abordées durant le tutoriel, tout d’abord :  Les propriétés de transformations en CSS3, ensuite le principe des border-radius et enfin les dégradés en CSS.

Nous devons maintenant choisir un modèle, une image que nous allons reproduire. Pour ce tutoriel, j’ai choisi le logo de l’agence Weode dont font parti les deux fondateurs de Livingtuts qui sont Gaétan Weltzer et Yoann Marie.

Cette image peut apparaître en apparence simple, mais vous verrez que c’est une autre histoire lorsqu’il s’agit de la réaliser en CSS. Pour cela, nous allons donc suivre un cheminement en 5 étapes : La base, La partie gauche, Le centre, La partie droite et enfin Les dégradés. Voici la version finale que vous devriez avoir à  la fin de ce tutoriel :

Demo Flash



Avant de commencer :

  1. Nous allons respecter dans ce tutoriel une syntaxe précise, cela permet de modifier le code plus facilement si cela est nécessaire. Pensez à  faire de même lors de vos autres réalisations.
  2. Les valeurs de placement, de hauteur ou de largeur peuvent changer d’une étape à  l’autre, de plus celles-ci sont données mais le tutoriel n’a aucun intérêt si vous n’effectuer pas le travail de recherche qui permet de les trouver.
  3. Pour ce tutoriel vous avez besoin de 2 logiciels : Chrome ou Safari et Notepad++.
  4. Vous avez aussi besoin de l’image fournie dans l’archive placé au tout début du tuto.
  5. Enfin, pensez à  faire des sauvegardes de manière systématique et à  tester votre travail, un plantage   ou une panne de courant est vite arrivé.


I.La base

1.Le conteneur de l’image

Notre image sera composée de nombreuses divs aux multiples positions, couleurs et formes, il faut donc un conteneur afin que notre réalisation ne parte pas dans tous les sens. Pour cela nous créons une simple div en positionnement relatif d’une largeur et d’une hauteur de 768 pixels.

Je vous rappelle notre but  : recréer une image uniquement avec CSS. Et vu qu’on cherche à  faire un travail qui respecte au plus l’original nous mettons en background l’image précédemment téléchargée.

Je ne m’attarde pas plus que ça sur l’architecture de notre page de départ, là  n’est pas le but du tutoriel et de toutes façons les fichiers de base vous sont fournis dans l’archive.

2. La forme

Notre but premier va être d’obtenir la forme simple de ‘W’. On remarque sans trop de difficulté que la forme est composé de 4 grandes parties,nous partons donc sur cette idée là , des modifications se feront peut être par la suite :).

Commençons donc par rajouter ces 4 divs à  notre code HTML.

PS : Je précise que certaines divs sont inutiles dans la créations du logo mais permettent seulement d’avoir un code clair et précis.

</pre>
<div>
 <!-- Conteneur de l'icone						-->
<div id="gauche">
 <!-- Partie Gauche								-->
<div id="g1"></div>
</div>
 <!-- /Partie Gauche								-->
<div id="centre">
 <!-- Partie centrale 							-->
<div id="gauche-centre">
 <!-- Partie Gauche centrale 					-->
<div id="gc1"></div>
 <!-- Bloc Principal								--></div>
<div id="droite-centre">
 <!-- Partie droite centrale						-->
<div id="dc1"></div>
 <!-- Bloc Principal                             --></div>
</div>
<div id="droite">
 <!-- Partie droite								-->
<div id="d1"></div>
</div>
 <!-- /Partie droite								--></div>
<pre>
												<!-- /Conteneur de l'icone						-->



Ajoutons à  ça un peu de css afin pouvoir voir apparaître ces divs.

/*=========================			Gauche		=========================*/
#g1
		{
		height: 50px;
		width: 50px;

		background: rgb(28,118,201);

		top: 0px;
		left: 0px;
		}

/*=========================			Centre		=========================*/

#gc1
		{
		height: 50px;
		width: 50px;

		background: rgb(28,118,201);

		top: 50%;
		left: 30%;
		}

#dc1
		{
		height: 50px;
		width: 50px;

		background: rgb(28,118,201);

		top: 50%;
		right: 30%;
		}

/*=========================			Droite		=========================*/
#d1
		{
		height: 50px;
		width: 50px;

		background: rgb(28,118,201);

		bottom: 0%;
		right: 0%;
		 }


Astuce  :
Vous remarquerez que dans le tout début du css, je précise que toutes les divs faisant parti du conteneur sont en positionnement absolut, cela nous permet de ne pas avoir à  rajouter à  chaque nouvelle balise la propriété en question.

Nous avons maintenant nos 4 divs mais cela ne ressemble pas encore beaucoup a notre W :-|

On va essayer d’arranger tout ça, mais avant laissez moi vous présentez 3 outils de transformation css qui sont mis à  notre disposition.

  1. Tout d’abord la fonction  : Rotate.  Comme son nom l’indique celle ci permet d’effectuer une rotation.Cette transformation se traduirait par la ligne  :
    -webkit-transform: rotate(20deg)



    • Skew est une fonction qui fonctionne sur deux axes, celui des ordonnées (x) et des abscisses (y) , on peut traduire Skew par  «  pencher   » ou  «  dévier   ». On pourra donc  «  dévier   » les différents axes d’un bloc afin de lui donne la forme que l’on souhaite obtenir.

    • Commençons par Skewx :Cette transformation se traduirait par la ligne  :
      -webkit-transform: skewx(20deg)
      



    • Ensuite par Skewy :Cette transformation se traduirait par la ligne  :
      -webkit-transform: skewy(20deg)
      



Je pense que ces shémas sont plus explicatifs que la plupart des articles que l’on pourrait lire, on précise quand même la syntaxe pour utiliser ses propriétés  :

transform  : skewx(xdeg)

transform  : skewy(xdeg)

transform  : rotate(xdeg)

Rappel  :
N’oubliez pas les particules -webkit- , -moz- et -o- afin de rendre compatible et compréhensible votre code pour tous les navigateurs.

Maintenant que vous connaissez vos outils comme les 5 doigts de la main  ou 6 pour les japonnais (humour noir quand tu nous tiens :mrgreen: ) commençons le chantier, vous pouvez débuter par  la partie que vous voulez mais je vous conseille d’aller de gauche à  droite.

Votre but à  ce niveau de la réalisation est de chercher les valeurs CSS pour reproduire au plus précis la forme du W,ne vous souciez pas des couleurs et ne modifier donc que le CSS pour le moment.

Astuce  :
Pour être plus précis dans votre travail, vous pouvez utiliser la propriété opacity, afin de superposer l’image et le CSS. Vous pouvez aussi modifier les couleurs de background afin de contraster et donc de mieux voir les différences.

Vous venez sûrement de rencontrer votre premier problème ( et ce ne sera pas le dernier je vous rassure), vous avez beau chercher vous n’arrivez pas à  obtenir la forme voulue ni pour la partie gauche ni pour la partie droite.

On va donc modifier le code HTML en rajoutant une div pour chaque côté, je vous rassure vous n’aurez pas à  rechercher toutes les valeurs , en effet, la largeur ou encore la rotation sont les mêmes que pour le premier bloc de chaque côté. ;-)

</pre>
<div>
 <!-- Conteneur de l'icone						-->
<div id="gauche">
 <!-- Partie Gauche								-->
<div id="g1"></div>
 <!-- La base inférieure(partie sombre)			-->
<div id="g2"></div>
 <!-- La base supérieure(partie sombre)			--></div>
 <!-- /Partie Gauche								-->
<div id="centre">
 <!-- Partie centrale 							-->
<div id="gauche-centre">
 <!-- Partie Gauche centrale 					-->
<div id="gc1"></div>
 <!-- Bloc Principal								--></div>
<div id="droite-centre">
 <!-- Partie droite centrale						-->
<div id="dc1"></div>
 <!-- Bloc Principal                             --></div>
</div>
<div id="droite">
 <!-- Partie droite								-->
<div id="d1"></div>
 <!-- Couche inférieure							-->
<div id="d2"></div>
 <!-- La base supérieur (partie sombre)			--></div>
 <!-- /Partie droite								--></div>
<pre>
												<!-- /Conteneur de l'icone						-->

Astuce  :
Dans Chrome vous pouvez modifier directement le CSS d’une div et immédiatement voir l’effet de votre modification. Il vous suffit de faire un clic droit et d’inspecter l’élément.

Maintenant que le code HTML a été corrigé , vous pouvez vous replongez dans le CSS. Vous devriez maintenant obtenir la forme de W souhaitée.

à€ ce stade du tutoriel, votre code CSS doit ressembler à  peu de chose près à  celui ci, si les valeurs ne sont pas tout à  fait identiques ne vous en faites pas, mais la marge de précision est d’environ 8 pixels ou degrés. En dessus votre code nécessite d’être retravaillé. ;-)

/*=========================			Boite		=========================*/
.box div
		{
		position:absolute;
		}

#gauche,
#gauche-centre,
#droite-centre,
#droite,
#centre
		{
		height:100%;
		width:100%;
		background:transparent;
		border:none;
		top:0;
		left:0;
		}

/*=========================			Gauche		=========================*/
#g1
		{
		height: 298px;
		width: 125px;

		background: rgb(28,118,201);

-webkit-transform:rotate(-38.2deg) skewy(-12deg);
   -moz-transform:rotate(-38.2deg) skewy(-12deg);
	 -o-transform:rotate(-38.2deg) skewy(-12deg);
		transform:rotate(-38.2deg) skewy(-12deg);

		top: 257px;
		left: 158px;
		}
#g2
		{
		height: 220px;
		width: 126px;

		background: rgb(29,118,201);

-webkit-transform: rotate(-38.2deg) skewy(39deg);
   -moz-transform: rotate(-38.2deg) skewy(39deg);
	 -o-transform: rotate(-38.2deg) skewy(39deg);
		transform: rotate(-38.2deg) skewy(39deg);

		top: 183px;
		left: 69px;
		}

/*=========================			Centre		=========================*/

#gc1
		{
		height: 125px;
		width: 208px;

		background: rgb(28,118,201);

-webkit-transform: rotate(-50deg) skewx(-12deg);
   -moz-transform: rotate(-50deg) skewx(-12deg);
	 -o-transform: rotate(-50deg) skewx(-12deg);
		transform: rotate(-50deg) skewx(-12deg);

		top: 313px;
		left: 250px;
		}

#dc1
		{
		height: 126px;
		width: 285px;

		background: rgb(28,118,201);

-webkit-transform: rotate(52deg) skewx(12deg);
   -moz-transform: rotate(52deg) skewx(12deg);
	 -o-transform: rotate(52deg) skewx(12deg);
		transform: rotate(52deg) skewx(12deg);

		z-index: 7;
		top: 343px;
		left: 286px;
		}

/*=========================			Droite		=========================*/
#d1
		{
		height: 118px;
		width: 294px;

		background: rgb(28,118,201);

-webkit-transform: rotate(-50deg) skewx(-12deg);
   -moz-transform: rotate(-50deg) skewx(-12deg);
	 -o-transform: rotate(-50deg) skewx(-12deg);
		transform: rotate(-50deg) skewx(-12deg);

		top: 347px;
		right: 88px;
		}
#d2
		{
		height: 220px;
		width: 119px;

		background: rgb(28,118,201);

-webkit-transform: rotate(40deg) skewy(-40deg);
   -moz-transform: rotate(40deg) skewy(-40deg);
	 -o-transform: rotate(40deg) skewy(-40deg);
		transform: rotate(40deg) skewy(-40deg);

		top: 173px;
		right: 73px;
		 }

Voilà  le résultat

Nous avons actuellement un W qui a une forme trait pour trait identique à  celui d’origine à  par pour un point : Les bordures.
En effet toutes les bordures de la lettres sont plus ou moins arrondies, c’est pourquoi je vais devoir vous expliquer comment fonctionne cette propriété CSS.

Comme pour « skew » lorsque l’on utile « border-radius » il faut prendre en compte les deux axes dont nous avons parlé  précédemment. J’avoue ne pas être extrêmement doué pour les explications détaillées , c’est pourquoi j’ai confectionné cette petite image qui vous permettra je pense, de mieux comprendre les border-radius ».

à€ partir de ça, je pense que vous pouvez réussir à  retrouver les arrondis de chaque coins. Pensez à  utiliser l’inspection d’élément de chrome.

Astuce:
Lorsque l’on applique de   nombreuses transformations à  une div tel que la  rotation ou le skew , on peut avoir du mal à  retrouver le haut, le bas ou encore la gauche et la droite de celle ci. Pour se faciliter la tâche, ajouter des règles CSS  permettant  de savoir simplement ou ceux ci se trouvent. Par exemple en mettant  une bordure jaune de 1 pixel en haut tandis qu’il y a une bordure rouge de 1 pixel à  droite.

La première grande partie de ce tutoriel est finie, vous avez normalement réussi à  atteindre notre but : Reproduire la forme de lettre. Votre code CSS ressemble actuellement à  ça :

/*=========================			Boite		=========================*/
.box div
		{
		position:absolute;
		}

#gauche,
#gauche-centre,
#droite-centre,
#droite,
#centre
		{
		height:100%;
		width:100%;
		background:transparent;
		border:none;
		top:0;
		left:0;
		}

/*=========================			Gauche		=========================*/
#g1
		{
		height: 298px;
		width: 125px;

		background: rgb(28,118,201);
		border-bottom-left-radius:25px;

-webkit-transform:rotate(-38.2deg) skewy(-12deg);
   -moz-transform:rotate(-38.2deg) skewy(-12deg);
	 -o-transform:rotate(-38.2deg) skewy(-12deg);
		transform:rotate(-38.2deg) skewy(-12deg);

		top: 257px;
		left: 158px;
		}
#g2
		{
		height: 220px;
		width: 126px;

		background: rgb(29,118,201);
		border-top-left-radius:25px 43px;
		border-top-right-radius: 5px;

-webkit-transform: rotate(-38.2deg) skewy(39deg);
   -moz-transform: rotate(-38.2deg) skewy(39deg);
	 -o-transform: rotate(-38.2deg) skewy(39deg);
		transform: rotate(-38.2deg) skewy(39deg);

		top: 183px;
		left: 69px;
		}

/*=========================			Centre		=========================*/

#gc1
		{
		height: 125px;
		width: 208px;

		background: rgb(28,118,201);
		border-top-right-radius: 25px;

-webkit-transform: rotate(-50deg) skewx(-12deg);
   -moz-transform: rotate(-50deg) skewx(-12deg);
	 -o-transform: rotate(-50deg) skewx(-12deg);
		transform: rotate(-50deg) skewx(-12deg);

		top: 313px;
		left: 250px;
		}

#dc1
		{
		height: 126px;
		width: 285px;

		background: rgb(28,118,201);
		border-bottom-right-radius: 25px;
		border-top-left-radius: 25px;

-webkit-transform: rotate(52deg) skewx(12deg);
   -moz-transform: rotate(52deg) skewx(12deg);
	 -o-transform: rotate(52deg) skewx(12deg);
		transform: rotate(52deg) skewx(12deg);

		z-index: 7;
		top: 343px;
		left: 286px;
		}

/*=========================			Droite		=========================*/
#d1
		{
		height: 118px;
		width: 294px;

		background: rgb(28,118,201);
		border-bottom-left-radius: 25px;

-webkit-transform: rotate(-50deg) skewx(-12deg);
   -moz-transform: rotate(-50deg) skewx(-12deg);
	 -o-transform: rotate(-50deg) skewx(-12deg);
		transform: rotate(-50deg) skewx(-12deg);

		top: 347px;
		right: 88px;
		}
#d2
		{
		height: 220px;
		width: 119px;

		background: rgb(28,118,201);
		border-top-right-radius: 25px 35px;
		border-top-left-radius: 5px;

-webkit-transform: rotate(40deg) skewy(-40deg);
   -moz-transform: rotate(40deg) skewy(-40deg);
	 -o-transform: rotate(40deg) skewy(-40deg);
		transform: rotate(40deg) skewy(-40deg);

		top: 173px;
		right: 73px;
		 }

II. La partie gauche

Entamons maintenant la partie gauche de notre W. Comme vous le voyez il est constitué de plusieurs couches :

Pour l’instant nous allons uniquement nous occuper du 3ème et 2ème plan.

1. L’arrière plan

C’est simple pour celui-ci on a déjà  créé la forme voulue dans la première partie, il ne nous reste donc plus qu’à  créer le dégradé que l’on peut apercevoir ici :

Donc tout d’abord on va utiliser la pipette de photoshop pour savoir de quelle couleur est constitué le dégradé, ici il va de :  #0f4773 (en bas) à   #1c76c9 (en haut).

Ensuite on essaye de voir qu’elle taille le dégradé fait à  peu près , je vous laisser chercher, personnellement je trouve :  131px soit environ  44% de la taille de notre div. On aura donc la fin de notre dégradé à  44%.

Maintenant que nous avons toutes les informations nécessaires direction :Colorzilla.com/gradient

L’éditeur de dégradé est le quasiment le même que celui de photoshop, vous avez donc   juste à  entrer les valeurs que nous avons trouvées. ;-)

Nous voilà  donc avec :

#g1
		{
		height: 298px;
		width: 125px;

		background: rgb(28,118,201);
		background: -moz-linear-gradient(top, rgba(28,118,201,1) 0%, rgba(27,117,200,1) 43%, rgba(57,110,172,1) 44%, rgba(15,71,114,1) 100%);
		background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(28,118,201,1)), color-stop(43%,rgba(27,117,200,1)), color-stop(44%,rgba(57,110,172,1)), color-stop(100%,rgba(15,71,114,1)));
		background: -webkit-linear-gradient(top, rgba(28,118,201,1) 0%,rgba(27,117,200,1) 43%,rgba(57,110,172,1) 44%,rgba(15,71,114,1) 100%);
		background: -o-linear-gradient(top, rgba(28,118,201,1) 0%,rgba(27,117,200,1) 43%,rgba(57,110,172,1) 44%,rgba(15,71,114,1) 100%);
		background: -ms-linear-gradient(top, rgba(28,118,201,1) 0%,rgba(27,117,200,1) 43%,rgba(57,110,172,1) 44%,rgba(15,71,114,1) 100%);
		filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#1c76c9', endColorstr='#0f4772',GradientType=0 );
		background: linear-gradient(top, rgba(28,118,201,1) 0%,rgba(27,117,200,1) 43%,rgba(57,110,172,1) 44%,rgba(15,71,114,1) 100%);
		border-bottom-left-radius:25px;

-webkit-transform:rotate(-38.2deg) skewy(-12deg);
   -moz-transform:rotate(-38.2deg) skewy(-12deg);
	 -o-transform:rotate(-38.2deg) skewy(-12deg);
		transform:rotate(-38.2deg) skewy(-12deg);

		z-index:10;
		top: 257px;
		left: 158px;
		}

à€ la place de :

#g1
		{
		height: 298px;
		width: 125px;

		background: rgb(28,118,201);
		border-bottom-left-radius:25px;

-webkit-transform:rotate(-38.2deg) skewy(-12deg);
   -moz-transform:rotate(-38.2deg) skewy(-12deg);
	 -o-transform:rotate(-38.2deg) skewy(-12deg);
		transform:rotate(-38.2deg) skewy(-12deg);

		top: 257px;
		left: 158px;
		}

2. Le 2ème plan

Comme vous aurez pu le remarquer le second plan est quasi-identique à  l’arrière plan, vous n’avez donc pas grand chose à  faire non plus dans cette sous partie.

On va simplement ajouter deux autres divs pour obtenir ceci :

</pre>
<div id="gauche">
 <!-- Partie Gauche								-->
<div id="g1"></div>
 <!-- La base inférieure(partie sombre)			-->
<div id="g2"></div>
 <!-- La base supérieure(partie sombre)			-->
<div id="g1-min"></div>
 <!-- La seconde base inférieure(partie claire)	-->
<div id="g2-min"></div>
 <!-- La seconde base supérieure(partie claire)	--></div>
<pre>

Puis on ajoute les mêmes caractéristiques de #g1 et #g2 à  #g1-min et #g2-min , en prenant soin, de réduire la taille afin que celle ci correspondent au mieux à  l’image de base. Je vous renvois bien sur à  l’astuce sur l’opacité et l’image de fond ;).

Maintenant que les bonnes mesures ont été trouvée, on change le background qui est ici :#b5d6ff.

Rappel : On oublie pas d’indiquer un z-index suffisant pour que les blocs s’affichent correctement ;)

On a donc un CSS semblable à  celui là  :

#g1
		{
		height: 298px;
		width: 125px;

		background: rgb(28,118,201);
		background: -moz-linear-gradient(top, rgba(28,118,201,1) 0%, rgba(27,117,200,1) 43%, rgba(57,110,172,1) 44%, rgba(15,71,114,1) 100%);
		background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(28,118,201,1)), color-stop(43%,rgba(27,117,200,1)), color-stop(44%,rgba(57,110,172,1)), color-stop(100%,rgba(15,71,114,1)));
		background: -webkit-linear-gradient(top, rgba(28,118,201,1) 0%,rgba(27,117,200,1) 43%,rgba(57,110,172,1) 44%,rgba(15,71,114,1) 100%);
		background: -o-linear-gradient(top, rgba(28,118,201,1) 0%,rgba(27,117,200,1) 43%,rgba(57,110,172,1) 44%,rgba(15,71,114,1) 100%);
		background: -ms-linear-gradient(top, rgba(28,118,201,1) 0%,rgba(27,117,200,1) 43%,rgba(57,110,172,1) 44%,rgba(15,71,114,1) 100%);
		filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#1c76c9', endColorstr='#0f4772',GradientType=0 );
		background: linear-gradient(top, rgba(28,118,201,1) 0%,rgba(27,117,200,1) 43%,rgba(57,110,172,1) 44%,rgba(15,71,114,1) 100%);
		border-bottom-left-radius:25px;

-webkit-transform:rotate(-38.2deg) skewy(-12deg);
   -moz-transform:rotate(-38.2deg) skewy(-12deg);
	 -o-transform:rotate(-38.2deg) skewy(-12deg);
		transform:rotate(-38.2deg) skewy(-12deg);

		z-index:10;
		top: 257px;
		left: 158px;
		}
#g2
		{
		height: 220px;
		width: 126px;

		background: rgb(29,118,201);
		border-top-left-radius:25px 43px;
		border-top-right-radius: 5px;

-webkit-transform: rotate(-38.2deg) skewy(39deg);
   -moz-transform: rotate(-38.2deg) skewy(39deg);
	 -o-transform: rotate(-38.2deg) skewy(39deg);
		transform: rotate(-38.2deg) skewy(39deg);

		top: 183px;
		left: 69px;
		}

#g1-min
        {

        height: 298px;
        width: 118px;

        background:#b7d9ff;
        border-bottom-left-radius:25px;

-webkit-transform:rotate(-38.2deg) skewy(-12deg) ;
   -moz-transform:rotate(-38.2deg) skewy(-12deg)  ;
     -o-transform:rotate(-38.2deg) skewy(-12deg)  ;
        transform:rotate(-38.2deg) skewy(-12deg)  ;

        z-index:11;
        top: 253px;
        left: 160px;
        }

#g2-min
        {
        height: 182px;
        width: 119px;

        background:#b7d9ff;
        border-top-left-radius: 22px 32px;
        border-top-right-radius: 5px;

-webkit-transform: rotate(-38.2deg) skewy(38deg);
   -moz-transform: rotate(-38.2deg) skewy(38deg)  ;
     -o-transform: rotate(-38.2deg) skewy(38deg)  ;
        transform: rotate(-38.2deg) skewy(38deg)  ;

        z-index: 11;
        top: 195px;
        left: 68px;
        }


III. Le centre

1. Partie gauche

#gc1
		{
		height: 125px;
		width: 208px;

		background: rgb(0,153,186);
		background: -moz-linear-gradient(top, rgba(0,153,186,1) 0%, rgba(4,110,130,1) 100%);
		background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(0,153,186,1)), color-stop(100%,rgba(4,110,130,1)));
		background: -webkit-linear-gradient(top, rgba(0,153,186,1) 0%,rgba(4,110,130,1) 100%);
		background: -o-linear-gradient(top, rgba(0,153,186,1) 0%,rgba(4,110,130,1) 100%);
		background: -ms-linear-gradient(top, rgba(0,153,186,1) 0%,rgba(4,110,130,1) 100%);
		filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#0099ba', endColorstr='#046e82',GradientType=0 );
		background: linear-gradient(top, rgba(0,153,186,1) 0%,rgba(4,110,130,1) 100%);
		border-top-right-radius: 25px;

-webkit-transform: rotate(-50deg) skewx(-12deg);
   -moz-transform: rotate(-50deg) skewx(-12deg);
	 -o-transform: rotate(-50deg) skewx(-12deg);
		transform: rotate(-50deg) skewx(-12deg);

		z-index:10;
		top: 313px;
		left: 250px;
		}
		#gc1:before
				{
				height: 125px;
				width: 45px;

				display: block;
				content: '';

				background:#27516f;

		-webkit-transform: rotate(1deg);
		   -moz-transform: rotate(1deg);
			 -o-transform: rotate(1deg);
				transform: rotate(1deg);

				z-index:11;
				top: 313px;
				left: 250px;
				}
		#gc1:after
				{
				height: 131px;
				width: 123px;

				display: block;
				content: '';

				background: rgb(4,194,209);
				background: -moz-linear-gradient(top, rgba(4,194,209,1) 0%, rgba(1,221,240,1) 100%);
				background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(4,194,209,1)), color-stop(100%,rgba(1,221,240,1)));
				background: -webkit-linear-gradient(top, rgba(4,194,209,1) 0%,rgba(1,221,240,1) 100%);
				background: -o-linear-gradient(top, rgba(4,194,209,1) 0%,rgba(1,221,240,1) 100%);
				background: -ms-linear-gradient(top, rgba(4,194,209,1) 0%,rgba(1,221,240,1) 100%);
				filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#04c2d1', endColorstr='#01ddf0',GradientType=0 );
				background: linear-gradient(top, rgba(4,194,209,1) 0%,rgba(1,221,240,1) 100%);
				border-top-left-radius: 25px;
				border-right:5px solid #07b8c6;

		-webkit-transform: rotate(90deg);
		   -moz-transform: rotate(90deg);
			 -o-transform: rotate(90deg);
				transform: rotate(90deg);

				z-index:11;
				margin-top: -127px;
				margin-left: 80px;
				}

La partie gauche centrale se construit en 3 parties.

Tout d’abord j’ai modifié le background du bloc principal #gc1 , puis j’ai utilisé les pseudo-classes :after et :before pour créer les deux autres blocs, cela me permet d’économiser des divs et donc d’avoir un code plus léger.

Le second avantage de ces pseudo-classes et que les transformations associées au bloc principal leur sont aussi associées, nous n’avons donc plus besoin de rechercher à  chaque fois de nouvelles valeurs pour les transformations CSS3, il faut cependant bien penser à  ajouter les 2 lignes sinon les blocs  n`apparaîtront  pas:

display: block;
content: '';

Enfin j’ai ajouté la ligne z-index à  chaque fois, afin de pouvoir superposer les blocs comme je le souhaite, plus la valeur de z-index, plus la couche qui y est liée sera haute.

Maintenant, j’ajoute une seconde div que je nomme gc2 afin de créer la bordure  supérieure  qu’on peut  apercevoir  ici en rouge :

J’utilise une seconde div car avec la propriété border, nous ne pourrions pas obtenir un rendu aussi précis ;)

On a donc :

</pre>
<div id="gauche-centre">
 <!-- Partie Gauche centrale 					-->
<div id="gc1"></div>
 <!-- Bloc Principal								-->
<div id="gc2"></div>
 <!-- Bordure Claire								--></div>
<pre>

et on ajoute le CSS de gc2:

#gc2
		{
		height: 125px;
		width: 208px;

		background: #00ffff;
		border-top-right-radius: 25px;

-webkit-transform: rotate(-50deg) skewx(-12deg);
   -moz-transform: rotate(-50deg) skewx(-12deg);
	 -o-transform: rotate(-50deg) skewx(-12deg);
		transform: rotate(-50deg) skewx(-12deg);

		z-index:2;
		top: 311px;
		left: 246px;
		}

2. La partie droite

#dc1
		{
		height: 126px;
		width: 285px;

		background: rgb(0,214,232);
		background: -moz-linear-gradient(left center, rgba(0,255,255,1) 0%, rgba(0,214,232,1) 50%);
		background: -webkit-gradient(linear, left top,right top, color-stop(0%,rgba(0,255,255,1)), color-stop(50%,rgba(0,214,232,1)));
		background: -webkit-linear-gradient(left center, rgba(0,255,255,1) 0%,rgba(0,214,232,1) 50%);
		background: -o-linear-gradient(left center, rgba(0,255,255,1) 0%,rgba(0,214,232,1) 50%);
		background: -ms-linear-gradient(left center, rgba(0,255,255,1) 0%,rgba(0,214,232,1) 50%);
		filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00d6e8', endColorstr='#00ffff',GradientType=0 );
		background: linear-gradient(left center, rgba(0,255,255,1) 0%,rgba(0,214,232,1) 50%);
		border-bottom-right-radius: 25px;
		border-top-left-radius: 25px;

-webkit-transform: rotate(52deg) skewx(12deg);
   -moz-transform: rotate(52deg) skewx(12deg);
	 -o-transform: rotate(52deg) skewx(12deg);
		transform: rotate(52deg) skewx(12deg);

		z-index: 7;
		top: 343px;
		left: 286px;
		}
		#dc1-1
				{
				height: 128px;
				width: 288px;

				overflow:hidden;

				background: rgb(10,233,249);
				background: -moz-linear-gradient(top, rgba(10,233,249,1) 0%, rgba(7,227,246,1) 100%);
				background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(10,233,249,1)), color-stop(100%,rgba(7,227,246,1)));
				background: -webkit-linear-gradient(top, rgba(10,233,249,1) 0%,rgba(7,227,246,1) 100%);
				background: -o-linear-gradient(top, rgba(10,233,249,1) 0%,rgba(7,227,246,1) 100%);
				background: -ms-linear-gradient(top, rgba(10,233,249,1) 0%,rgba(7,227,246,1) 100%);
				filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#0ae9f9', endColorstr='#07e3f6',GradientType=0 );
				background: linear-gradient(top, rgba(10,233,249,1) 0%,rgba(7,227,246,1) 100%);

				border-top-left-radius: 25px;
				border-bottom-right-radius: 25px;

		-webkit-transform: scale(.9);
		   -moz-transform: scale(.9);
			 -o-transform: scale(.9);
				transform: scale(.9);

				z-index:7;
				top: -1px;
				left: 8px;
				}
				#dc1-1-1
						{
						height: 170px;
						width: 251px;

						background:#08eaff;
						border-top-left-radius: 64px 41px;

				-webkit-transform: rotate(211deg);
				   -moz-transform: rotate(211deg);
					 -o-transform: rotate(211deg);
						transform: rotate(211deg);

						left: 81px;
						top: -75px;
						}

Ici la réalisation se fait en cinq parties.  Tout d’abord on modifie le dégradé du bloc principal, ensuite on crée une div à  l’intérieur de dc1, elle nous servira de conteneur pour le dégradé oblique et en même temps on y ajoute un dégradé. On remarque l’utilisation de la propriété scale , celle ci permet tout simplement de changer la taille de notre bloc , ici sa valeur est (.9) nous réduisons donc le bloc à  90% de sa taille originelle, donc ici 90% de 128px et 288px.

Son utilité n’est pas franchement vérifiée ici ( je l’avoue ! :lol:   ) mais je tenais simplement à  vous montrer que celle ci existait, et que dans certaines situations elle peut se  révéler  bien utile, je vous donnerai un exemple dans la fin de ce tutoriel. ;-)

Pour le dégradé oblique, rien bien compliqué, on applique une rotation , on cache le superflu grâce à  overflow:hidden et le tour est joué.   Vous pourrez peut être rencontré un problème d’arrondi avec l’un des angles , malheureusement, nous ne pouvons pas vraiment le compenser pour le moment, penser donc à  chercher des valeurs approchées pour le border-radius, afin d’avoir quelqu’un chose d’à  peu près arrondi ;-)

Côté html on a donc ça :

</pre>
<div id="dc1">
 <!-- Bloc Principal                             -->
<div id="dc1-1">
 <!-- Partie Claire								-->
<div id="dc1-1-1"></div>
 <!-- Reflet 1 (dégradé)							--></div>
 <!--/Partie Claire								--></div>
<pre>

On va maintenant s’occuper du « reflet » en bas à  droite, il faut donc ajouter une div nommée dc1-1-2 , on lui applique un background de couleur #08EAFF , puis on utilise la pseudo-classe  :before pour pouvoir créer un effet similaire à  celui ci :

Pour obtenir ce résultat : On utilise les propriétés skew et rotation. #dc1-1-2:before est de la même couleur que #dc1-1-1.

Enfin, nous en finissons avec la partie centrale avec deux nouvelles divs :

</pre>
<div id="droite-centre">
 <!-- Partie droite centrale						-->
<div id="dc1">
 <!-- Bloc Principal                             -->
<div id="dc1-1">
 <!-- Partie Claire								-->
<div id="dc1-1-1"></div>
 <!-- Reflet 1 (dégradé)							-->
<div id="dc1-1-2"></div>
 <!-- Reflet 2									--></div>
 <!--/Partie Claire								--></div>
<div id="dc2"></div>
 <!-- Ombre 1									-->
<div id="dc3"></div>
 <!-- Ombre 2									--></div>
<pre>

Elles servent à  créer ces deux bordures :

Ici , rien de compliqué non plus , faites juste bien attention aux différentes valeurs de z-index. ;-)

Au final vous obtenez ceci :

#dc2
		{
		height: 125px;
		width: 48px;

		display: block;
		content: '';

		background: #0ddce6;

-webkit-transform: rotate(54deg) skewx(12deg);
   -moz-transform: rotate(54deg) skewx(12deg);
	 -o-transform: rotate(54deg) skewx(12deg);
		transform: rotate(54deg) skewx(12deg);

		z-index: 7;
		top: 318px;
		left: 383px;
		}
#dc3
		{
		height: 116px;
		width: 121px;

		background: #245775;

		-webkit-transform: rotate(54deg) skewx(12deg);
		-moz-transform: rotate(54deg) skewx(12deg);
		-o-transform: rotate(54deg) skewx(12deg);
		transform: rotate(54deg) skewx(12deg);

		z-index: 6;
		top: 404px;
		left: 423px;
		}

IV. La droite

/
*=========================         Droite      =========================*/
#d1
        {
        height: 107px;
        width: 294px;

        background:cyan;
        border-bottom-left-radius: 25px;

-webkit-transform: rotate(-50deg) skewx(-12deg);
   -moz-transform: rotate(-50deg) skewx(-12deg);
     -o-transform: rotate(-50deg) skewx(-12deg);
        transform: rotate(-50deg) skewx(-12deg);

        top: 343px;
        right: 89px;
        z-index:4;
         }

        #d1:before
                {
                height: 116px;
                width: 294px;

                display: block;
                content: '';

                background: rgb(0,153,186);
                background: -moz-linear-gradient(top, rgba(0,153,186,1) 0%, rgba(4,110,130,1) 100%);
                background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(0,153,186,1)), color-stop(100%,rgba(4,110,130,1)));
                background: -webkit-linear-gradient(top, rgba(0,153,186,1) 0%,rgba(4,110,130,1) 100%);
                background: -o-linear-gradient(top, rgba(0,153,186,1) 0%,rgba(4,110,130,1) 100%);
                background: -ms-linear-gradient(top, rgba(0,153,186,1) 0%,rgba(4,110,130,1) 100%);
                filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#0099ba', endColorstr='#046e82',GradientType=0 );
                background: linear-gradient(top, rgba(0,153,186,1) 0%,rgba(4,110,130,1) 100%);
                border-bottom-left-radius: 25px;

                margin-top: 3px;
                 }
#d2
        {
        height: 220px;
        width: 118px;

        background: rgb(28,118,201);
        border-top-right-radius: 25px 35px;
        border-top-left-radius: 5px;

-webkit-transform: rotate(40deg) skewy(-40deg);
   -moz-transform: rotate(40deg) skewy(-40deg);
     -o-transform: rotate(40deg) skewy(-40deg);
        transform: rotate(40deg) skewy(-40deg);

        top: 173px;
        right: 75px;
         }
#d3
        {
        height: 315px;
        width: 122px;
        overflow: hidden;
        background: transparent;
        border-top-right-radius: 43px 35px;
        border-top-left-radius: 5px;

        -webkit-transform: rotate(40deg) skewy(-40deg);
        -moz-transform: rotate(40.2deg) skewy(-40deg);
        -o-transform: rotate(40.2deg) skewy(-40deg);
        transform: rotate(40.2deg) skewy(-40deg);

        z-index: 5;
        top: 168px;
        right: 107px;

        }
        #d3-1
                {
                height: 298px;
                width: 119px;

                background: rgb(56,110,173);
                background: -moz-linear-gradient(top, rgba(56,110,173,1) 0%, rgba(56,110,173,1) 50%, rgba(42,92,153,1) 75%, rgba(31,77,138,1) 100%);
                background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(56,110,173,1)), color-stop(50%,rgba(56,110,173,1)), color-stop(75%,rgba(42,92,153,1)), color-stop(100%,rgba(31,77,138,1)));
                background: -webkit-linear-gradient(top, rgba(56,110,173,1) 0%,rgba(56,110,173,1) 50%,rgba(42,92,153,1) 75%,rgba(31,77,138,1) 100%);
                background: -o-linear-gradient(top, rgba(56,110,173,1) 0%,rgba(56,110,173,1) 50%,rgba(42,92,153,1) 75%,rgba(31,77,138,1) 100%);
                background: -ms-linear-gradient(top, rgba(56,110,173,1) 0%,rgba(56,110,173,1) 50%,rgba(42,92,153,1) 75%,rgba(31,77,138,1) 100%);
                filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#386ead', endColorstr='#1f4d8a',GradientType=0 );
                background: linear-gradient(top, rgba(56,110,173,1) 0%,rgba(56,110,173,1) 50%,rgba(42,92,153,1) 75%,rgba(31,77,138,1) 100%);

        -webkit-transform: rotate(0deg) skewy(47deg);
           -moz-transform: rotate(0deg) skewy(47deg);
             -o-transform: rotate(0deg) skewy(47deg);
                transform: rotate(0deg) skewy(47deg);

                top: -51px;
                right: 2px;
                border-top-right-radius: 11px;
}

Dans cette quatrième et avant dernière partie, nous nous attaquons à  la partie droite du logo, pour cette partie, on réutilise quasiment tout ce qui a été vu avant.

Tout d’abord , on applique une couleur cyan pour la « couche inférieur » puis on utilise la pseudo-classe :before pour créer le dégradé qui va de  #0099BA à  #046E82.


Vous pouvez écrire background : cyan, la couleur sera reconnue !

Ensuite , on ajoute une div nommée d3 ainsi qu’une autre div à  l’intérieur de celle-ci nommée d3-1, d3 fait office de conteneur, il doit simplement empêcher le dégradé de d3-1 de dépasser en haut, la forme oblique en bas du dégradé est donnée par l’utilisation de skew sur d3-1.

N’oubliez pas overflow:hidden ;-)

Enfin nous réalisons la même opération que pour la partie gauche, on crée une partie plus claire avec   deux nouvelles divs à  l’intérieur de d3-1. J’utilise la propriété scale par flemmardise et j’assume ;-) , je n’ai pas à  chercher de nouvelles valeurs, je multiplie simplement par 0.9.

				#d3-1-1
						{
						height: 176px;
						width: 83px;

						overflow: hidden;

						background: #B5D6FF;
						border-bottom-left-radius: 5px;
						border-top-left-radius: 25px 35px;

				-webkit-transform: scale(.9) rotate(43.2deg) skewy(48deg);
				   -moz-transform: scale(.9) rotate(43.2deg) skewy(48deg);
					 -o-transform: scale(.9) rotate(43.2deg) skewy(48deg);
						transform: scale(.9) rotate(43.2deg) skewy(48deg);

						z-index: 7;
						top: 17px;
						right: 19px;

						}
				#d3-1-2
						{
						height: 205px;
						width: 119px;

						overflow: hidden;

						background: #B5D6FF;
						border-bottom-left-radius: 5px;
						border-top-left-radius: 25px 35px;</pre>
<div>-webkit-transform: scale(.9) rotate(-2deg) skewx(-3deg);</div>
<div>-moz-transform: scale(.9) rotate(-2deg) skewx(-3deg);</div>
<div>-o-transform: scale(.9) rotate(-2deg) skewx(-3deg);</div>
<div>transform: scale(.9) rotate(-2deg) skewx(-3deg);</div>
<pre>
-webkit-transform: scale(.9) rotate(-2deg) skewx(-3deg);

						z-index: 6;
						top: 94px;
						right: 3px;
						}

Nous avons un maintenant une page HTML qui ressemble à  ceci :

</pre>
<div class="box">
 <!-- Conteneur de l'icone						-->
<div id="gauche">
 <!-- Partie Gauche								-->
<div id="g1"></div>
 <!-- La base inférieure(partie sombre)			-->
<div id="g2"></div>
 <!-- La base supérieure(partie sombre)			-->
<div id="g1-min"></div>
 <!-- La seconde base inférieure(partie claire)	-->
<div id="g2-min"></div>
 <!-- La seconde base supérieure(partie claire)	--></div>
 <!-- /Partie Gauche								-->
<div id="centre">
 <!-- Partie centrale 							-->
<div id="gauche-centre">
 <!-- Partie Gauche centrale 					-->
<div id="gc1"></div>
 <!-- Bloc Principal								-->
<div id="gc2"></div>
 <!-- Bordure Claire								--></div>
<div id="droite-centre">
 <!-- Partie droite centrale						-->
<div id="dc1">
 <!-- Bloc Principal                             -->
<div id="dc1-1">
 <!-- Partie Claire								-->
<div id="dc1-1-1"></div>
 <!-- Reflet 1 (dégradé)							-->
<div id="dc1-1-2"></div>
 <!-- Reflet 2									--></div>
 <!--/Partie Claire								--></div>
<div id="dc2"></div>
 <!-- Ombre 1									-->
<div id="dc3"></div>
 <!-- Ombre 2									--></div>
</div>
<div id="droite">
 <!-- Partie droite								-->
<div id="d1"></div>
 <!-- Couche inférieure							-->
<div id="d2"></div>
 <!-- La base supérieur (partie sombre)			-->
<div id="d3">
 <!-- Conteneur base inférieure					-->
<div id="d3-1"></div>
 <!-- Base inférieure (partie sombre)			--></div>
</div>
 <!-- /Partie droite								--></div>
<pre>
												<!-- /Conteneur de l'icone						-->

V. Les dégradés

Nous voilà  à  la fin du tutoriel , il ne nous reste plus qu’à  faire les dégradés qui sont dans chaque partie. Sauf que ici nous sommes confrontés à  un problème de taille, il n’existe aucun moyen de ne pas utiliser d’image pour   contenir ces dégradés, à  cause de leurs formes trop complexes, que vous pouvez voir ici en noir.

Et comme je l’ai dit plus haut, notre but est de n’utiliser absolument aucune image et d’avoir pour seule requête HTTP le fichier CSS.

Nous allons donc utiliser une image, sans pour autant augmenter le nombre de requête ! Pour cela nous allons simplement utiliser les data URI. Derrière ce nom barbare, ce cache une technique révolutionnaire qui permet de remplacer une image par du simple code ( parfois lourd) ce qui augmente la taille de nos fichiers mais en échange diminue le nombre de requête.

Je vous invite donc à  vous munir de l’outil Plume de Photoshop afin de détourer les deux parties qui nous intéressent pour au final obtenir ces deux images :

Nous les convertissons maintenant au format voulu grâce à  ce site internet : dataurl.net

Il vous suffit de faire un « glisser/déposer » avec les deux images puis de copier le code donné , vous obtenez pour la première image (gauche) :



Et pour l’image de droite :



Maintenant, il vous suffit de créer deux divs nommées gd et dd, vous intégrer les codes obtenu comme si ceci étaient des images pour un background , puis enfin , vous trouvez le bon positionnement.
Votre page HTML ressemble à  ceci :

</pre>
<div id="gd"></div>
<div id="dd"></div>
<div id="gauche">
 <!-- Partie Gauche								-->
<div id="g1"></div>
 <!-- La base inférieure(partie sombre)			-->
<div id="g2"></div>
 <!-- La base supérieure(partie sombre)			-->
<div id="g1-min"></div>
 <!-- La seconde base inférieure(partie claire)	-->
<div id="g2-min"></div>
 <!-- La seconde base supérieure(partie claire)	--></div>
<pre>
											<!-- /Partie Gauche								--></pre>
<div id="centre">
 <!-- Partie centrale 							-->
<div id="gauche-centre">
 <!-- Partie Gauche centrale 					-->
<div id="gc1"></div>
 <!-- Bloc Principal								-->
<div id="gc2"></div>
 <!-- Bordure Claire								--></div>
<div id="droite-centre">
 <!-- Partie droite centrale						-->
<div id="dc1">
 <!-- Bloc Principal                             -->
<div id="dc1-1">
 <!-- Partie Claire								-->
<div id="dc1-1-1"></div>
 <!-- Reflet 1 (dégradé)							-->
<div id="dc1-1-2"></div>
 <!-- Reflet 2									--></div>
 <!--/Partie Claire								--></div>
<div id="dc2"></div>
 <!-- Ombre 1									-->
<div id="dc3"></div>
 <!-- Ombre 2									--></div>
</div>
<div id="droite">
 <!-- Partie droite								-->
<div id="d1"></div>
 <!-- Couche inférieure							-->
<div id="d2"></div>
 <!-- La base supérieur (partie sombre)			-->
<div id="d3">
 <!-- Conteneur base inférieure					-->
<div id="d3-1">
 <!-- Base inférieure (partie sombre)			-->
<div id="d3-1-1"></div>
 <!-- Seconde base supérieure (partie claire)	-->
<div id="d3-1-2"></div>
 <!-- Seconde base inférieure (partie claire)	--></div>
 <!-- /Base inférieure							--></div>
</div>
<pre>
											<!-- /Partie droite								-->

Et vous venez d’ajouter ce morceau de CSS :

/*=========================Dégradé droite/gauche=========================*/

#gd
		{
		height: 335px;
		width: 326px;
		background: url();

		overflow: hidden;

		z-index: 20;
		top: 219px;
		left: 19px;
		}

#dd
		{
		height: 209px;
		width: 247px;

		background: url();
		overflow: hidden;

		z-index: 20;
		top: 209px;
		left: 510px;
		}

Conclusion


Nous avons fini notre icône, comme vous le voyez cela ne fut pas aussi simple qu’on aurait pu le penser. Si il fallait retenir certaines choses de tout ce que nous avons pu voir dans ce tutoriel, je dirais tout d’abord que CSS3 propose une multitude de propriétés qui sont inutilisées et qui méritaient d’être mise en valeur, avec de l’imagination nous pouvons tous faire, les data URI c’est magique , mais surtout : les techniques utilisées aujourd’hui sont très récentes ( je vous ai mis un résumé tout en bas du tutoriel ), ou du moins compatibles uniquement avec les navigateurs à  jour tel que Chrome 11 ou Firefox 7, n’utilisez pas cette méthode de création dans le cas d’un site grand public, vous perdriez énormément de visites.  Voilà  voilà , c’est tout   ce que j’ai à  dire (ça fait déjà  beaucoup !) j’espère que ce tutoriel vous aura permis d’améliorer vos connaissances, d’enrichir votre savoir, et surtout, qu’il vous aura plu. :-)

Liste des points abordés

  • Perfectionnement des connaissances en positionnement CSS (relative,absolute,..)
  • Utilisation des transformations CSS3 2D (rotate, skewx,skewy)
    Syntaxe : -prefix- transform : modif(xdeg);
  • -prefix-:   -webkit- ,  -moz- ,  -ms- ,  -o- , ou -khtml- .
    modif : rotate , skew , skewx ou skewy .
    x : le degré de transformation.
  • Manipulation des pseudo-classes :before et :after
  • Utilisation des data URI

9 Comments to “Réaliser une icône ou un logo en CSS3”

  • Très bon tutoriel qui montre la puissance du CSS3. Cela étant, les limites de cette méthode ont été dîtes… Il faut que les utilisateurs soient sur des navigateurs récents. Le seul avantage que je trouverais à cette méthode serait la vitesse de chargement. Si tout le logo reste en HTML et CSS, il devrait être chargé plus rapidement qu’un fichier image.

  • Alors là j’ai du mal à comprendre… OK, c’est une belle prouesse technique, c’est assez bien réalisé et le résultat final est parfait, je ne reviens pas la dessus. Mais je pensais que l’orientation de ce site était : des techniques de professionnels.

    Or ce genre de hack, c’est bien pour faire des démos ou participer à des concours mais personne ne les utiliserai en production, ça serait juste aberrant. Déjà c’est pas le bon outil, c’est contre productif et ça ne présente aucun intérêt réel.

    Bref je reste dubitatif sur la présence du tutoriel ici, par rapport à l’orientation du site.

    Mwea : j’espère que tu ne prendras pas mal ma remarque, qui est plus une interrogation et ne remet pas en cause la qualité de ta réalisation.

    • Bonjour jb,
      Tout d’abord, merci pour ton retour, positif ou négatif c’est toujours bon à prendre, ça permet de progresser. ;)

      Ensuite effectivement, l’orientation de ce site internet est (non pas « était » comme tu as pu le dire) : Des techniques de professionnels. Le tutoriel que je propose ici, est basé sur un logo d’une extrême complexité, il permet aux développeurs d’intégrer les fonctions avancées de CSS3 qui seront d’ici peu utilisable pour tous les sites internet.

      Pour moi, l’intérêt est évident pour des sites de type portfolio, un développeur capable de telles « prouesses » est capable de plus encore. Cela permet de mettre en avant nos capacités.

      Pour ce qui est des sites grands publics, je suis d’accord avec toi. POUR L’INSTANT, cela est totalement contre productifs ne présente aucun intérêt car trop incompatible. Je l’ai d’ailleurs dis dans ma conclusion.

      Enfin, ici sont présentées des techniques de transformations CSS inutilisables pour la plupart, mais bien d’autres points sont abordés, les data URI sont utilisables sur tous les navigateurs jusqu’à IE7, je rappelle le fonctionnement des positionnement en CSS, l’utilisation de :after et :before, etc..

      J’espère avoir éclairer ta lanterne ;)

      Mwea.

  • Absolument génial, tant pour le résultat que pour l’apprentissage du CSS 3.

    Merci pour le partage, j’en apprends bcp sur votre site.

    Bonne continuation ;-)

  • Pas forcément utile dans la pratique, je ne me vois pas faire un logo en CSS3 pour un client, mais c’est effectivement utile pour pouvoir perfectionner sa connaissance du CSS3 ou comme dit dans un autre commentaire pour montrer ses capacités.

  • La vache, j’imaginais pas que sa pouvais se faire en CSS3, je suis époustouflé. Bravo !

  • Bel exercice pour mettre en application les nouvelles propriétés apportées par CSS3.

    J’espère pouvoir lire encore de très bons tutos sur votre blog.

    Cordialement.

  • C’est : http://dataurl.net/ et non http://datauri.com ^^ faut mettre à jour un peu :p

  • Enorme……….

Laisser un commentaire