AccueilDernières imagesRechercherS'enregistrerConnexion

Forum de graphisme, codage et game design proposant des tutoriels, astuces, libres services et commandes dans les domaines de l'infographie amateur, de l'intégration web (HTML et CSS essentiellement) ainsi que dans la conception de RPG sur forum.

Le Deal du moment :
Cartes Pokémon 151 : où trouver le ...
Voir le deal

    Navigation en forme d'horloge

    Onyx
    Onyx
    FémininAge : 30Messages : 3350

    Lun 23 Juin 2014 - 20:25

    Rappel du premier message :




    Navigation en forme d'horloge


    Salut !

    Voici un petit LS d'une barre de navigation en forme d'horloge dont l'aiguille pointe sur les liens survolés qui a été fait pour la demande de Dastan.

    Pour l'aperçu, cliquez juste ici.

    Ce code est en trois parties.
    • Tout d'abord, nous allons supprimer l'ancienne navigation et la remplacer par la notre dans le template "Overhall Header".
    • Ensuite, nous allons mettre notre navigation en forme en allant ajouter certains éléments dans le CSS.
    • Enfin, nous allons ajouter un petit javascript pour savoir qu'un nouveau message privé est arrivé dans notre messagerie. D'ailleurs, pour cette partie, je me suis servie de ce tuto : http://www.school-of-pub.net/t11850-fa-totalement-personnaliser-la-barre-de-nav.


    Mettre un crédit vers Never-Utopia est obligatoire si vous utilisez ce LS.



    1. Corps de la navigation (Template Overhall_Header)


    Pour commencer, nous allons devoir nous débarrasser de la navigation normale afin qu'elle arrête de nous traîner dans les jambes.
    Comment?
    Nous allons carrément la supprimer.

    Elle devrait normalement se trouver entre les lignes 273 et 277. Voici à quoi elle ressemble :
    Code:
    <table cellspacing="0" cellpadding="0" border="0" align="{MENU_POSITION}">
     <tr>
     <td align="{MENU_POSITION}"{MENU_NOWRAP}>{GENERATED_NAV_BAR}</td>
     </tr>
     </table>


    Une fois que c'est fait, il est temps d'ajouter notre propre navigation. Du coup, au même endroit où était positionné l'ancienne barre de navigation, nous allons venir mettre le code suivant :
    Code:
    <table cellspacing="0" cellpadding="0" border="0" align="left">
     <tr>
                                              <td align="left">
       <div class="nav_bloc" align="center">
        <div class="navv" id="accueil"><a href="/forum"><img src="https://i.imgur.com/BleQNVF.png" alt="Accueil" /></a></div>
        <div class="navv" id="rechercher"><a href="/search"><img src="https://i.imgur.com/ILyNbqm.png" alt="Rechercher" /></a></div>
        <div class="navv" id="membres"><a href="/memberlist"><img src="https://i.imgur.com/smihrYB.png" alt="Membres" /></a></div>
        <div class="navv" id="groupes"><a href="/groups"><img src="https://i.imgur.com/0TCFuVf.png" alt="Groupes" /></a></div>
                                                        <div class="navv" id="profil"><a href="/profile?mode=editprofile"><img src="https://i.imgur.com/Fur3amR.png" alt="Profil" /></a></div>
          <!-- BEGIN switch_user_logged_in -->
        <div class="navv" id="mp"><a href="/privmsg?folder=inbox"><img src="https://i.imgur.com/AEQMua4.png" alt="MP" id="mpO" /></a></div>
                                                        <div class="navv" id="off"><a href="/login?logout"><img src="https://i.imgur.com/1WWhoBy.png" alt="Déconnexion" /></a></div>
          <!-- END switch_user_logged_in -->
          <!-- BEGIN switch_user_logged_out -->
                                                        <div class="navv" id="s_inscrire"><a href="/register"><img src="https://i.imgur.com/gFDkg6v.png" alt="S'inscrire" /></a></div>
                                                        <div class="navv" id="on"><a href="/login"><img src="https://i.imgur.com/1WWhoBy.png" alt="Connexion" /></a></div>
          <!-- END switch_user_logged_out -->
                                                        <div class="navv" id="nav_aiguille"></div>
                                                        <div style="visibility: hidden;">{GENERATED_NAV_BAR}</div>
          </div></td>
     </tr>
     </table>

    Donc, histoire de comprendre un peu ce qu'on a fait, nous allons regarder un peu le code que nous venons de rajouter :

    • Au tout début, il y a une table qui nous permet de positionner notre navigation, de la même façon qu'avec la navigation normale.
    • Ensuite, nous avons une "div" avec la class "nav_bloc". C'est le bloc avec l'image de l'horloge en background qui contient tous les liens de la navigation.
    • Puis, nous avons diverses "div" avec les liens de notre navigation. C'est séparé en trois parties :
      • Les liens que tout le monde peut voir.
      • Les liens entre le "BEGIN switch_user_logged_in" et "END switch_user_logged_in" que seuls les membres connectés peuvent voir.
      • Les liens entre "BEGIN switch_user_logged_out" et le "END switch_user_logged_out" que seuls les invités peuvent voir.
    • En avant dernier, nous avons l'aiguille qui tourne selon le lien sur lequel notre curseur est placé.
    • Enfin, nous avons l'ancienne navigation "GENERATED_NAV_BAR" qui est invisible mais qui nous sera utile pour récupérer le code des nouveaux MPs.

    À l’exception des images de l'aiguille et de l'horloge, toutes les images des liens peuvent être modifiées à cette étape.



    2. Mise en forme (CSS)


    Si vous avez installé le code dans le template, vous voyez sans doute tout de suite que ce n'est pas super du tout pour le moment.

    Du coup, nous allons mettre en forme notre navigation à l'aide du code suivant que j'expliquerai ensuite :
    Code:
                  /*NAVIGATION*/

    /*Bloc de l'horloge*/
    .nav_bloc {
      background-image: url('https://i.imgur.com/u2wxcxS.png');
      width: 300px;
      height: 300px;
      position: relative;
      display: block;
      margin-top: -190px;
      margin-left: 30px;
    }

    /*Trucs pour les liens*/
    .navv {
      position: absolute;
      display: block;
      z-index: 2;
    }

    /*Aiguille*/
    #nav_aiguille {
      background-image: url('https://i.imgur.com/QpoF06N.png');
      width: 14px;
      height: 244px;
      bottom: 32px;
      left: 140px;
      -webkit-transform: rotate(0deg);
      transform: rotate(0deg);
      transition: 0.5s;
      -webkit-transition: 0.5s;
      z-index: 1;
    }

    /*Positionnement des liens*/
    #accueil {
      width: 100px;
      height: 27px;
      bottom: 260px;
      left: 101px;
      -webkit-transform:rotate(1deg);
      transform:rotate(1deg);
    }
    #rechercher {
      width: 131px;
      height: 35px;
      bottom: 200px;
      left: 184px;
      -webkit-transform:rotate(57deg);
      transform:rotate(57deg);
    }
    #membres {
      width: 94px;
      height: 28px;
      bottom: 100px;
      left: 218px;
      -webkit-transform:rotate(109deg);
      transform:rotate(109deg);
    }
    #groupes {
      width: 99px;
      height: 32px;
      bottom: 21px;
      left: 144px;
      -webkit-transform:rotate(157deg);
      transform:rotate(157deg);
    }
    #profil {
      width: 79px;
      height: 28px;
      bottom: 25px;
      left: 55px;
      -webkit-transform:rotate(205deg);
      transform:rotate(205deg);
    }
    #mp {
      width: 115px;
      height: 39px;
      bottom: 120px;
      left: -31px;
      -webkit-transform:rotate(265deg);
      transform:rotate(265deg);
    }
    #off, #on {
      width: 80px;
      height: 31px;
      bottom: 225px;
      left: 26px;
      -webkit-transform:rotate(315deg);
      transform:rotate(315deg);
    }
    #s_inscrire {
      width: 107px;
      height: 37px;
      bottom: 120px;
      left: -27px;
      -webkit-transform:rotate(263deg);
      transform:rotate(263deg);
    }

    /*Mouvement de l'aiguille selon le lien survolé*/
    #accueil:hover ~ #nav_aiguille {
      -webkit-transform:rotate(2deg);
      transform:rotate(2deg);
    }
    #rechercher:hover ~ #nav_aiguille {
      -webkit-transform:rotate(57deg);
      transform:rotate(57deg);
    }
    #membres:hover ~ #nav_aiguille {
      -webkit-transform:rotate(109deg);
      transform:rotate(109deg);
    }
    #groupes:hover ~ #nav_aiguille {
      -webkit-transform:rotate(157deg);
      transform:rotate(157deg);
    }
    #profil:hover ~ #nav_aiguille {
      -webkit-transform:rotate(205deg);
      transform:rotate(205deg);
    }
    #mp:hover ~ #nav_aiguille {
      -webkit-transform:rotate(265deg);
      transform:rotate(265deg);
    }
    #s_inscrire:hover ~ #nav_aiguille {
      -webkit-transform:rotate(263deg);
      transform:rotate(263deg);
    }
    #on:hover ~ #nav_aiguille, #off:hover ~ #nav_aiguille {
      -webkit-transform: rotate(315deg);
      transform: rotate(315deg);
    }

                   /*FIN NAVIGATION*/


    Maintenant, pour ceux qui veulent comprendre ce qu'ils font à la place de faire du copier/coller, nous allons découper certaines parties de ce CSS afin de comprendre comment cela fonctionne.

    Premièrement, le bloc de l'horloge :
    Code:
    /*Bloc de l'horloge*/
    .nav_bloc {
      background-image: url('https://i.imgur.com/u2wxcxS.png');
      width: 300px;
      height: 300px;
      position: relative;
      display: block;
      margin-top: -190px;
      margin-left: 30px;
    }

    • Le "background-image" est image de l'horloge.
    • Le "width" est la largeur de l'image de l'horloge et est importante puisque cela délimite la largeur du bloc également.
    • Le "height" est la hauteur de l'image de l'horloge et est importante puisque cela délimite la hauteur du bloc également.
    • La "position: relative" indique que s'il y a d'autres div à l'intérieur du bloc, leur position sera définie par rapport à la largeur et à la hauteur du bloc de l'horloge.
    • Le "display: block;" indique que le bloc de l'horloge est un bloc.
    • Le "margin-top: -190px" permet de déplacer le bloc de 190px vers le haut, à savoir sur la bannière.
    • Le "margin-left: 30px" permet de déplacer le bloc de 30px vers la droite.



    Deuxièmement, certaines caractéristiques des liens :
    Code:
    /*Trucs pour les liens*/
    .navv {
      position: absolute;
      display: block;
      z-index: 2;
    }

    • La "position: absolute" veut dire que la position des liens sont automatiquement liés aux bordures du bloc de l'horloge.
    • Le "display: block" indique que les liens sont des blocs.
    • Le " z-index: 2" indique que les liens sont au-dessus des éléments qui ont un "z-index" inférieur à 2 et en-dessous des éléments qui ont un "z-index" supérieurs à 2.



    Troisièmement, l'aiguille comme elle est initialement :
    Code:
    /*Aiguille*/
    #nav_aiguille {
      background-image: url('https://i.imgur.com/QpoF06N.png');
      width: 14px;
      height: 244px;
      bottom: 32px;
      left: 140px;
      -webkit-transform: rotate(0deg);
      transform: rotate(0deg);
      -webkit-transition: 0.5s;
      transition: 0.5s;
      z-index: 1;
    }

    • Le "background-image" est image de l'aiguille.
    • Le "width" est la largeur de l'image de l'aiguille et est importante puisque cela délimite la largeur du bloc également.
    • Le "height" est la hauteur de l'image de l'aiguille et est importante puisque cela délimite la hauteur du bloc également.
    • Le "bottom" indique que le bloc de l'aiguille est à 32px du bas du bloc de l'horloge.
    • Le "left" indique que le bloc de l'aiguille est à 140px du côté gauche du bloc de l'horloge.
    • Le "transform: rotate(0deg);" indique que le bloc de l'aiguille reste droit.
    • Le "transition: 0.5s;" indique que les mouvements de l'aiguille seront d'une durée de 0,5 seconde.
    • Le " z-index: 1" indique que les liens sont au-dessus des éléments qui ont un "z-index" inférieur à 1 et en-dessous des éléments qui ont un "z-index" supérieurs à 1.



    Quatrièmement, le positionnement des liens de la navigation. Comme ils sont tous basés sur le même principe, je prendrai le lien de "rechercher" comme exemple :
    Code:
    #rechercher {
      width: 131px;
      height: 35px;
      bottom: 200px;
      left: 184px;
      -webkit-transform:rotate(57deg);
      transform:rotate(57deg);
    }

    • Le "width" est la largeur de l'image de rechercher et est importante puisque cela délimite la largeur du bloc également.
    • Le "height" est la hauteur de l'image de rechercher et est importante puisque cela délimite la hauteur du bloc également.
    • Le "bottom" indique que le bloc de rechercher est à 200px du bas du bloc de l'horloge.
    • Le "left" indique que le bloc de rechercher est à 184px du côté gauche du bloc de l'horloge.
    • Le "transform: rotate(57deg);" indique que le bloc de rechercher est tourné de 57 degrés vers la droite.



    Dernièrement, le déplacement de l'aiguille en fonction du lien survolé. Comme ils sont tous basés sur le même principe, je prendrai le lien de "rechercher" comme exemple :
    Code:
    #rechercher:hover ~ #nav_aiguille {
      -webkit-transform:rotate(57deg);
      transform:rotate(57deg);
    }

    • Le "#rechercher:hover ~ #nav_aiguille" veut dire que quand le bloc "#rechercher" (bloc de rechercher) est survolé, il y a l'effet suivant sur le bloc "#nav_aiguille" (bloc de l'aiguille).
    • Le "transform: rotate(57deg);" indique que le bloc de l'aiguille tourne de 57 degrés vers la droite. Normalement, la rotation devrait être la même que celle qui a été appliquée sur le bloc rechercher.


    J'ai modifié tous les liens des images et tout est décalé! Qu'est-ce que je fais maintenant?
    Premièrement, va lire les explications du CSS si tu ne l'as pas fait.
    Ensuite, il va falloir repositionner chaque lien modifié avec leurs attributs "bottom", "left" et "rotate".
    N'oublie pas d'aller ajuster la rotation de l'aiguille avec la nouvelle rotation de tes liens !
    Enfin... bonne chance pour ce casse-tête Twisted Evil 



    3. Nouveau MP (Javascript)


    Avec la navigation de base, il y a une image différente que celle de la messagerie normale lorsqu'il y a un nouveau message. Seulement, ce n'est pas une fonction automatique si on fait sa propre barre de navigation. Du coup, nous allons reproduire cet effet !

    Pour cela, nous allons aller dans :
    > PANNEAU D'ADMINISTRATION
    > > MODULES
    > > > HTML & JAVASCRIPT
    > > > > GESTION DES CODES JAVASCRIPT

    À ce même endroit, si vous n'avez pas activé la gestion des javascripts, il faut le faire avant de faire tout autre chose.

    Ensuite, nous allons "créer un nouveau javascript".
    Il va falloir lui choisir un nom. Ex: "Nouveau MP"
    Ensuite, il va falloir cocher le Placement "Sur toutes les pages".

    Puis, on va y coller le code suivant :
    Code:
    jQuery().ready(function(){
            
            /* On prend l'élément du menu de base pour savoir s'il y a un nouveau message */
            var e= $("#i_icon_mini_new_message");
            
            /* Si il y en a pas, on s'arrête là */
            if(!e.length) return;
            
            /* S'il y en a, l'image changera pour l'image de nouveau message*/
            $("#mpO").attr('src','https://i.imgur.com/uTwYE10.png');
          
          
            });

    Cette partie de code est expliquée directement dans le code alors on va en rester là ^^




    C'est tout! Si jamais vous avez des problèmes avec ce LS, n'hésitez pas à passer dans Un problème avec mon code ou Personnalisations si vous voulez personnaliser le LS et que vous avez besoin d'aide.

    À plus !


    Merci de laisser un message pour donner vos impressions/commentaires/remerciements ^^


    Dernière édition par Onyx le Ven 22 Fév 2019 - 2:37, édité 8 fois
    avatar
    Luti
    FémininAge : 33Messages : 18

    Ven 16 Jan 2015 - 15:35

    Ca c'est ce que j'appelle une navigation classe ! Merci !
    Irissia87
    Irissia87
    FémininAge : 36Messages : 124

    Ven 16 Jan 2015 - 19:00

    merci pour le tuto :)
    Ouat
    Ouat
    FémininAge : 40Messages : 74

    Sam 17 Jan 2015 - 10:12

    Superbe travail
    Kahlane
    Kahlane
    FémininAge : 38Messages : 12

    Mar 20 Jan 2015 - 12:16

    Très sympa comme rendu, merci!
    mikalus
    mikalus
    MasculinAge : 53Messages : 92

    Ven 23 Jan 2015 - 5:28

    Eh eh eh !...
    Voilà ce que l'on appelle de la créativité... Wink



    Navigation en forme d'horloge - Page 8 766500banpub
    Tyragrio
    Tyragrio
    MasculinAge : 43Messages : 15

    Lun 26 Jan 2015 - 12:21

    merci et très jolie vous avez du en passer du temps
    Nephilime
    Nephilime
    FémininAge : 28Messages : 147

    Lun 26 Jan 2015 - 13:40

    Wah, c'est juste superbe *w*
    Je vais essayer de voir si je peux la mettre, merci beaucoup Onyx !
    avatar
    Lucrèce
    FémininAge : 34Messages : 68

    Sam 31 Jan 2015 - 11:04

    C'est magnifique, merci beaucoup !
    Tyragrio
    Tyragrio
    MasculinAge : 43Messages : 15

    Sam 31 Jan 2015 - 14:04

    J'arrive pas a y mettre j'y comprend rien
    okeane
    okeane
    FémininAge : 33Messages : 93

    Dim 1 Fév 2015 - 19:07

    merci =)
    katastukye
    katastukye
    FémininAge : 32Messages : 26

    Dim 1 Fév 2015 - 23:22

    C'est très original!!!! Merci!



    Kiki85
    Kiki85
    MasculinAge : 29Messages : 398

    Lun 2 Fév 2015 - 23:08

    Très atypique et très original en effet ! :)
    Blue Star
    Blue Star
    FémininAge : 24Messages : 30

    Mar 3 Fév 2015 - 13:03

    Magnifique et original !
    Merci. **
    Haniwa
    Haniwa
    FémininAge : 29Messages : 206

    Mer 4 Fév 2015 - 13:47

    Merci
    F.a.m.e
    F.a.m.e
    MasculinAge : 34Messages : 12

    Sam 14 Fév 2015 - 11:44

    Je n'avais jamais vu une navigation comme ça, c'est sympa ^^
    Velvet-Mist
    Velvet-Mist
    FémininAge : 33Messages : 45

    Sam 14 Fév 2015 - 22:11

    Wow sublime! Merci beaucoup!
    Saphiina
    Saphiina
    FémininAge : 29Messages : 26

    Lun 16 Fév 2015 - 15:50

    L'idée est vraiment géniale :o merci :3
    Abby Reever
    Abby Reever
    FémininAge : 32Messages : 146

    Dim 22 Fév 2015 - 4:15

    Haaaan génial! *-*
    Kianda
    Kianda
    MasculinAge : 23Messages : 88

    Dim 22 Fév 2015 - 16:50

    MAGNIFIQUE <3 Merci beaucoup !



    Navigation en forme d'horloge - Page 8 1416416855-kandiasigna
    Thalia Grace
    Thalia Grace
    FémininAge : 27Messages : 66

    Dim 22 Fév 2015 - 18:01

    Merci beaucoup! ♥
    Idril Palanén
    Idril Palanén
    FémininAge : 31Messages : 83

    Lun 23 Fév 2015 - 15:12

    J'adore, je trouve l'effet très original et je me demande si je ne vais pas l'utiliser pour mon forum d'ailleurs. En tout cas, merci à toi pour nous avoir proposé ce tuto ! :)
    Champi
    Champi
    FémininAge : 32Messages : 23

    Lun 23 Fév 2015 - 23:31

    Hello !!
    Je prend c'est pire trop cool !!! Merci !!



    Spoiler:
    Eywa
    Eywa
    FémininAge : 38Messages : 14

    Ven 27 Fév 2015 - 9:38

    C'est vraiment original j'aime beaucoup
    chabus
    chabus
    FémininAge : 31Messages : 21

    Dim 1 Mar 2015 - 16:06

    Merci, c'est super original et ça me donne envie d'essayer^^
    Vador
    Vador
    MasculinAge : 23Messages : 64

    Dim 1 Mar 2015 - 16:23

    Merci.
    Contenu sponsorisé


      La date/heure actuelle est Mar 7 Mai 2024 - 7:46