AccueilFAQRechercherMembresGroupesS'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.


    Design changeant selon l'heure (bannière, fond et autres)

    Partagez
    avatar
    Neva
    FémininAge : 25Messages : 18555

    le Dim 22 Sep 2013 - 16:33

    Rappel du premier message :


    Le code n'est pas caché sous balise hide, mais n'hésitez pas à remercier son auteur :)
    Lien pour comprendre pourquoi le contenu n'est pas sous hide


    RAPPELS :
    - Si vous avez un problème avec ce tutoriel, n'hésitez pas à poser vos questions mais faîtes-le ici : http://www.never-utopia.com/f177-probleme-avec-mon-code  (relisez le tutoriel en entier avant de le faire et, lorsque vous ouvrez votre sujet, fournissez l'adresse de ce tutoriel, le lien de votre forum ainsi que les codes CSS/Javascript/template posant problème)

    Salut à tous !

    Je vous propose un tutoriel permettant de modifier l’apparence de votre forum selon l’heure (que ce soit pour faire un effet jour/nuit, matin/après-midi, un changement pour seulement une heure ou deux dans la journée...). Les deux exemples proposés se concentreront sur la modification du fond du forum et la modification de la bannière mais je vous invite à tenter vos propres personnalisations =)

    A SAVOIR :  
    - Le code utilise l’heure de votre ordinateur donc, une fois le code installé, vous pouvez changer l’heure sur votre ordinateur et recharger la page pour tester les différentes périodes.  
    - Les codes javascript sont à insérer dans panneau d'admin > modules > gestion des codes javascript
    - Sur la page "Gestion des codes javascript", pensez à activer les codes en cochant "oui" après "Activer la gestion des codes Javascript" et en enregistrant.




    MODIFIER LE FOND DU FORUM ENTRE LE JOUR ET LA NUIT


    Tout d’abord, commencez par mettre votre image de fond pour la nuit à l’endroit habituel (panneau d’administration > affichage > gestion des images > mode avancé > Image du fond de page : collez l’adresse sur cette ligne et validez) et vérifiez qu’elle apparaît bien.

    Ensuite, nous n’avons besoin que d’un peu de JavaScript.

    Voici le code en question :
    Code:
    jQuery(document).ready(function(){var date = new Date();
            var heure = date.getHours();
            if(heure >= 7 && heure < 18){
              $("body").css("background-image", "url('ADRESSE FOND JOUR')");
            }
    });

    PERSONNALISATION :
    Sur la troisième ligne, vous pouvez voir que j’ai défini le jour comme étant entre 7h et 18h. Vous pouvez modifier ces chiffres selon vos désirs (ne touchez qu’aux chiffres).
    Attention, nous travaillons sur une base de 24h : 3h ne peut être que 3h du matin, on utilisera 15h pour 3h de l’après-midi.

    Sur la quatrième ligne, pensez à remplacer ADRESSE FOND JOUR par l’adresse de ladite image (faites attention à ne pas supprimer les apostrophes, l’adresse doit être écrite entre).

    Juste pour bien résumer, l'image que vous avez mise dans vos images est celle qui apparaît normalement et l'image mise dans le javascript est celle qui apparaît pendant la plage de temps inscrite dans le javascript.

    INSTALLATION :
    Une fois complété, le code est à mettre dans panneau d'admin > modules > gestion des javascript. Cochez bien la case Sur toutes les pages

    Et voilà, c’est tout ce qu’il y a à faire ! =)




    MODIFIER LA BANNIERE


    Tout d’abord, commencez par mettre votre bannière pour la nuit à l’endroit habituel (panneau d’administration > affichage > gestion des images > mode avancé > logo : collez l’adresse sur cette ligne et validez) et vérifiez qu’elle apparaît bien.

    Ensuite, il nous faut nos quelques lignes de JavaScript :
    Code:
    jQuery(document).ready(function(){var date = new Date();
            var heure = date.getHours();
            if(heure >= 8 && heure < 19){
              $("#pun-logo img,#i_logo,#logo img").attr("src", "ADRESSE FOND JOUR");
            }
    });


    PERSONNALISATION :
    Sur la troisième ligne, vous pouvez voir que j’ai défini le jour comme étant entre 7h et 18h. Vous pouvez modifier ces chiffres selon vos désirs (ne touchez qu’aux chiffres).
    Attention, nous travaillons sur une base de 24h : 3h ne peut être que 3h du matin, on utilisera 15h pour 3h de l’après-midi.

    Sur la quatrième ligne, pensez à remplacer ADRESSE FOND JOUR par l’adresse de ladite image (faites attention à ne pas supprimer les apostrophes, l’adresse doit être écrite entre).



    Si la taille de la bannière de jour diffère de celle de nuit, il vous faut compléter et utiliser ce code :
    Code:
    jQuery(document).ready(function(){var date = new Date();
            var heure = date.getHours();
            if(heure >= 8 && heure < 19){
              $("#pun-logo img,#i_logo,#logo img").attr("src", "ADRESSE FOND JOUR");
              $("#pun-logo img,#i_logo,#logo img").css("width", "LARGEUR EN PX");
              $("#pun-logo img,#i_logo,#logo img").css("height", "HAUTEUR EN PX");
            }
    });

    INSTALLATION :
    Une fois complété, le code est à mettre dans panneau d'admin > modules > gestion des javascript. Cochez bien la case Sur toutes les pages




    COMBINER LES DEUX CODES


    Si vous souhaitez modifier votre bannière ET votre fond, lisez les deux explications plus haut et suivez la démarche pour le template et le CSS de la bannière mais utilisez ce JavaScript :
    Code:
    jQuery(document).ready(function(){var date = new Date();
            var heure = date.getHours();
            if(heure >= 8 && heure < 19){
              $("#pun-logo img,#i_logo,#logo img").attr("src", "ADRESSE FOND JOUR");
              $("body").css("background-image", "url('ADRESSE FOND JOUR')");
            }
    });




    RAJOUTER DES TRANCHES HORAIRES


    Pour rajouter des tranches horaires, il suffit de reproduire la partie de code qui suit (il s'agit du code pour changer le fond, je vous donne plus bas les parties pour les deux autres codes) en en changeant les infos et en collant  après le } de la précédente et avant le " }); " de fin :

    Code:
           if(heure >= 7 && heure < 18){
              $("body").css("background-image", "url('ADRESSE FOND JOUR')");
            }

    Voilà ce que ça donnerait en ajoutant un 19-23h :
    Code:
    jQuery(document).ready(function(){var date = new Date();
            var heure = date.getHours();
            if(heure >= 7 && heure < 18){
              $("body").css("background-image", "url('ADRESSE FOND 7-18h')");
            }
            if(heure >= 19 && heure < 23){
              $("body").css("background-image", "url('ADRESSE FOND 19-23h')");
            }
    });

    Pour la bannière, c'est cette partie que vous devez copier/coller/remplir avec les nouvelles infos de la même façon :
    Code:
            if(heure >= 8 && heure < 19){
              $("#pun-logo img,#i_logo,#logo img").attr("src", "ADRESSE FOND JOUR");
            }

    Et cette partie pour le code combinant les deux effets :
    Code:
            if(heure >= 8 && heure < 19){
              $("#pun-logo img,#i_logo,#logo img").attr("src", "ADRESSE FOND JOUR");
              $("body").css("background-image", "url('ADRESSE FOND JOUR')");
            }




    AUTRES :


    Bien que cette astuce ait été fait avec la bannière et le fond en tête, il faut comprendre que cela peut fonctionner pour n'importe quoi.

    Petit exemple où je veux qu'un bloc avec l'id "bloc_bleu" devienne rouge de 8 à 19h :
    Code:
    /*Partie html*/
    <div id="bloc_bleu">Je suis un bloc bleu qui devient rouge de 8 à 19h.</div>

    /*Partie javascript*/
    jQuery(document).ready(function(){var date = new Date();
            var heure = date.getHours();
            if(heure >= 8 && heure < 19){
              $("#bloc_bleu").css("background-color", "red");
            }
    });

    Petit exemple où je veux qu'une image avec l'id "image_quelconque" change d'images de 8 à 19h :
    Code:
    /*Partie html*/
    <img id="image_quelconque" src="ADRESSE FOND NUIT" />

    /*Partie javascript*/jQuery(document).ready(function(){var date = new Date();
            var heure = date.getHours();
            if(heure >= 8 && heure < 19){
              $("#image_quelconque").attr("src", "ADRESSE FOND JOUR");
            }
    });

    Bref, on sélectionne notre "id" avec le $("#JeSuisUnId") au début en changeant le "JeSuisUnId" par le nom de l'id de notre bloc/image.
    Ensuite, on utilise .attr("src", "ADRESSE FOND JOUR"); pour changer l'adresse de l'image (seulement pour les images).
    Ou, on utilise .css("propriété", "valeur"); pour changer une valeur dans le css, que cela soit le background-image, la couleur de l'écriture, etc.




    CONSEILS SUPPLEMENTAIRES :
    - En cas de problème, vérifiez bien tous les signes de ponctuation
    - Pour faire apparaître/disparaître un élément, jouez sur la propriété display (je pense notamment à display: none; pour faire disparaître votre bannière)


    Dernière édition par Neva le Dim 19 Oct 2014 - 0:55, édité 4 fois
    avatar
    RainboWolf
    FémininAge : 20Messages : 86

    le Mer 7 Oct 2015 - 15:57

    Waah c'est parfait ! Merci. **
    avatar
    Spring
    FémininAge : 15Messages : 110

    le Dim 18 Oct 2015 - 18:05

    super! **



    avatar
    Kanra
    FémininAge : 16Messages : 113

    le Dim 1 Nov 2015 - 10:32

    Merci
    avatar
    Kaht
    MasculinAge : 27Messages : 13

    le Lun 16 Nov 2015 - 13:53

    merci !! Very Happy
    avatar
    MaelStrhom
    MasculinAge : 21Messages : 38

    le Ven 20 Nov 2015 - 5:50

    Oh, génial comme concept :0
    avatar
    patriciadpt30
    FémininAge : 54Messages : 240

    le Ven 27 Nov 2015 - 12:59

    merci pour voir hi hi hi



    Patricia :)
    avatar
    Smikyou
    FémininAge : 23Messages : 85

    le Dim 29 Nov 2015 - 4:40

    ty
    avatar
    Alexielios
    FémininAge : 25Messages : 61

    le Dim 29 Nov 2015 - 12:32

    Merci pour ce tuto :) Je compte changer selon la date, j'espère que ça m'aiderai :)










    "People live their lives bound by what they accept as correct and true. That's how they define reality.
    But what does it mean to be correct or true?"
    avatar
    Tria
    FémininAge : 20Messages : 125

    le Sam 12 Déc 2015 - 21:58

    Wouah *^* C'est génial comme idée. Merci !



    "Tomber est permis, se relever est ordonné."
    avatar
    Myrcella Heaven
    FémininAge : 20Messages : 53

    le Dim 20 Déc 2015 - 2:04

    Merci !
    avatar
    Otulissa
    FémininAge : 20Messages : 18

    le Lun 21 Déc 2015 - 11:58

    Eh c'est plutôt cool merci du partage !
    avatar
    Tamashia
    FémininAge : 15Messages : 45

    le Mer 27 Jan 2016 - 18:02

    merci du partage ! **



    avatar
    MeowLowDee
    FémininAge : 25Messages : 72

    le Ven 29 Jan 2016 - 12:23

    Merci, c'est trop bien !
    avatar
    Soleilou
    FémininAge : 16Messages : 45

    le Jeu 4 Fév 2016 - 16:14

    Merci, c'est exactement ce que je recherche !
    avatar
    Kilda
    FémininAge : 36Messages : 69

    le Dim 7 Fév 2016 - 10:38

    merci
    avatar
    NanoiHime
    FémininAge : 18Messages : 519

    le Ven 12 Fév 2016 - 11:33

    Mercii





    avatar
    Haaken
    FémininAge : 23Messages : 43

    le Jeu 18 Fév 2016 - 19:27

    Wow, cette idée quoi ♥ merci pour le partage !
    avatar
    Sephy
    FémininAge : 23Messages : 134

    le Sam 20 Fév 2016 - 22:02


    Woaaah =D ça à l'air intéressant !
    Merci du partage !
    avatar
    Ombinou
    FémininAge : 22Messages : 104

    le Mar 23 Fév 2016 - 20:00

    Merci ^^
    avatar
    Lilihir
    FémininAge : 19Messages : 14

    le Mar 23 Fév 2016 - 21:49

    Merci pour ce fabuleux tuto ! L'idée est originale et puis, je pense que ça va plaire à énormément de monde !
    avatar
    Brises
    FémininAge : 18Messages : 18

    le Sam 27 Fév 2016 - 22:13

    C'est super bien ! Merci du partage
    avatar
    FanDeFofo
    MasculinAge : 40Messages : 16

    le Mer 2 Mar 2016 - 16:44

    h
    avatar
    Jaspe
    MasculinAge : 14Messages : 20

    le Jeu 3 Mar 2016 - 15:28

    Originale, ça peut être utile, merchi





    Merci beaucoup Alil' !

    avatar
    miss69
    FémininAge : 33Messages : 40

    le Dim 6 Mar 2016 - 2:37

    plop !

    merci beaucoup pour ce code :)
    avatar
    Anviree
    FémininAge : 20Messages : 49

    le Lun 7 Mar 2016 - 16:35

    trop fort !
    Contenu sponsorisé


      La date/heure actuelle est Mar 25 Avr 2017 - 12:25