IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

JavaScript Discussion :

Opacité sur événement mouseout


Sujet :

JavaScript

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Intégrateur Web
    Inscrit en
    Novembre 2012
    Messages
    14
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Intégrateur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Novembre 2012
    Messages : 14
    Par défaut Opacité sur événement mouseout
    Bonjour,

    Je rencontre un problème pour changer l'opacité d'une image au retrait de la souris (mouseout). J'arrive bien à lui donner l'opacité que je souhaite au moment du survol mais impossible de lui définir l'opacité au retrait de la souris.
    J'appelle la même fonction au survol et au retrait et j'ai définit mes événements dans une fonction setup.

    Voici le code utilisé :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
     
    function modifyOpacity(id, opacity) {
    	var tt = document.getElementById(id);
    	var currentOpacity = img1.objGetOpacity();
    	if (currentOpacity > 0.5) {
              currentOpacity -= 0.1;
    	  img1.objSetOpacity(currentOpacity);
    	  setTimeout("modifyOpacity()", 20);
        } else if (currentOpacity < 1) {
    	  currentOpacity += 0.1;
    	  img1.objSetOpacity(currentOpacity);
    	  setTimeout("modifyOpacity()", 20);
    	}
    }
    function changeOpacity(evnt) {
    	if (evnt.type == "mouseover") {
    	  modifyOpacity("picto_facebook", 0.5);
    	} else if (evnt.type == "mouseout") {
    	  modifyOpacity("picto_facebook", 0.9);
    	}
    }
    function setup() {
      img = document.getElementById("picto_facebook");
      img1 = new ImgObj(img);
      // Valeur d'opacité initiale
      img1.objSetOpacity(0.9);
      // Evénements
      img.addEventListener("mouseover", changeOpacity, false);
      img.addEventListener("mouseout", changeOpacity, false);
    }
    window.onload=setup;

  2. #2
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Billets dans le blog
    20
    Par défaut
    Tu as un gros problème de logique dans modifyOpacity() (en dehors du paramètre opacity non utilisé).
    Lorsque tu survoles l'image, tu diminue l'opacité, mais dans chaque condition, tu relances un setTimeout(), donc l'image va éternellement osciller entre 0.4 (cas où l'appel suivant va ajouter 0.1) et 0.5 (cas où l'appel suivant va retirer 0.1).
    Il y a un moment où il faut stopper le timer...
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
    Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

  3. #3
    Membre averti
    Homme Profil pro
    Intégrateur Web
    Inscrit en
    Novembre 2012
    Messages
    14
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Intégrateur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Novembre 2012
    Messages : 14
    Par défaut
    Ok je comprend ce que tu veux dire pour le timer mais est il possible d'utiliser la même fonction pour les événements mouseover et mouseout, ou bien faut il impérativement créer une fonction pour chaque événement ?

  4. #4
    Modérateur

    Avatar de NoSmoking
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    17 211
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 211
    Par défaut
    Bonjour,
    tu peux jeter un coup d'oeil à Galerie avec effet de fondu, tiens c'est de Bovino me semble t-il !

  5. #5
    Membre averti
    Homme Profil pro
    Intégrateur Web
    Inscrit en
    Novembre 2012
    Messages
    14
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Intégrateur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Novembre 2012
    Messages : 14
    Par défaut
    Bon finalement je suis reparti de zero après avoir suivi quelques tutos et explications sur le fonctionnement des timers.

    J'ai réussis à faire quelque chose qui fonctionne mais un bug se produit quand je rentre et sors trop rapidement sur l'élément.

    Voici mon code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
     
    function fadeOut(id, downOpacity, speed) {
     
    	var currentOpacity = id.style.opacity * 100;
    	// Si l'élément n'a pas d'opacité définit
    	if(!currentOpacity) {
    		// On définit une valeur par défaut
    		setOpacity(id, 100);
    		currentOpacity = id.style.opacity * 100;
    	}
    	var timer = window.setInterval(function() {
            currentOpacity -= 1;
            id.style.opacity = currentOpacity / 100;
            if (currentOpacity === downOpacity) {
    	        window.clearInterval(timer);
            }
        }, speed/1000);
    }
    function fadeIn(id, upOpacity, speed) {
     
    	var currentOpacity = id.style.opacity * 100;
    	var timer = window.setInterval(function() {
            currentOpacity += 1;
            id.style.opacity = currentOpacity / 100;
            if (currentOpacity === upOpacity) {
    	        window.clearInterval(timer);
    	        //alert(currentOpacity);
            }
        }, speed/1000);
    }
    function setOpacity(id, opacity) {
    	id.style.opacity = opacity / 100;
    }
     
    addEvent(getById("picto_facebook"), "mouseover", function(){
    	fadeOut(this, 40, 5)
    });
    addEvent(getById("picto_facebook"), "mouseout", function(){
    	fadeIn(this, 86, 5)
    });
    Merci pour le lien.

  6. #6
    Modérateur

    Avatar de NoSmoking
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    17 211
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 211
    Par défaut
    Ton dysfonctionnement provient du fait que tu ne "clear" pas le timer en cours avant d'en lancer un autre, il te faut donc le "clearer" en début de fonction.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    function fadeOut(id, downOpacity, speed) {
    	// init iTimer si not existe and kill
    	id.iTimer = id.iTimer || null;
    	window.clearInterval( id.iTimer);
     
    	var currentOpacity = id.style.opacity * 100;
    	// Si l'élément n'a pas d'opacité définit
    	if(!currentOpacity) {
    		// On définit une valeur par défaut
    		setOpacity(id, 100);
    		currentOpacity = id.style.opacity * 100;
    	}
            // on utilise id.iTimer par la suite
    	id.iTimer = window.setInterval(function() {
            currentOpacity -= 1;
            id.style.opacity = currentOpacity / 100;
            if (currentOpacity === downOpacity) {
                    window.clearInterval( id.iTimer);
            }
        }, speed/1000);
    }

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [DOM] Pb gestion de l'évènement mouseout sur une <DIV>
    Par rvux69 dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 22/01/2007, 21h27
  2. Problème sur évènement d'une liste déroulante
    Par krfa1 dans le forum Access
    Réponses: 7
    Dernier message: 05/05/2006, 08h03
  3. Opacité sur bloc Div - Incompatibilité et ne fonctionne pas
    Par killprog dans le forum Balisage (X)HTML et validation W3C
    Réponses: 2
    Dernier message: 15/03/2006, 15h31
  4. Problème sur évènement
    Par Azharis dans le forum Access
    Réponses: 2
    Dernier message: 12/01/2006, 16h36
  5. [O9i][Win][OMS]Erreur sur événement
    Par Fabien Celaia dans le forum Oracle
    Réponses: 4
    Dernier message: 05/11/2004, 15h00

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo