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 :

Evènement OnkeyDown + IE


Sujet :

JavaScript

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Avril 2008
    Messages
    37
    Détails du profil
    Informations forums :
    Inscription : Avril 2008
    Messages : 37
    Par défaut Evènement OnkeyDown + IE
    Bonjour,

    J'ai un problème sur le OnKeyDown ous IE. En effet, j'affecte une fonction Javascript sur cet évênement, et dans cette fonction je regarde la touche pressée (e.which), et je modifie les background des différentes DIV sur ma page

    (pour résumer : j'ai un damier avec un personnage au centre, et le personnage bouge de case en case : -> 1 case = 1 DIV / -> image du personnage = background de la DIV / -> changement de case -> changement de background des 2 DIV's concernées).

    Sous Firefox ça marche nickel, mais pas sous IE. J'ai essayé avec un table à la place des DIV, avec des images aussi, mais rien ne marche.
    j'ai cherché un peu partout (FAQ comprise), et je n'ai trouvé aucune solution pour régler ça.

    Quelqu'un pourrait-il m'éclairer ?
    Merci beaucoup, je n'ai pas beaucoup de temps pour trouver une bonne solution.

  2. #2
    Expert éminent

    Homme Profil pro
    Inscrit en
    Janvier 2007
    Messages
    13 474
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2007
    Messages : 13 474
    Par défaut
    Bonjour,
    on voit bien le fonctionnement normal, mais ... quel est le problème ?
    (et le code concerné)

    A+

  3. #3
    Membre averti
    Inscrit en
    Avril 2008
    Messages
    37
    Détails du profil
    Informations forums :
    Inscription : Avril 2008
    Messages : 37
    Par défaut
    Alors pour le problème, c'est dit dans mon message mais peut-être pas assez explicite : dans mes DIV, l'image de déplace bien sous Firefox, mais reste fixe sous IE (donc ça vient soit du OnKeyDown, soit des backgrounds des DIV qui sont mal pris en compte sous IE).

    Voici le code du déplacement de l'image :

    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
    41
    42
    43
    44
    function keyDown(e)//Gestion des déplacements
    {   
    	e = e.which;
     
    	switch (e)
    	{
    	    case 37:
    	        if ((UserX == XMin) && (XMin == 0))
    	            return;
    	        document.getElementById("x"+UserX+"y"+UserY).style.background= "";
    	        UserX--;
    	        if (UserX < XMin)
    	            scroll();
    	        document.getElementById("x"+UserX+"y"+UserY).style.background= UserImage;
    	        break;
    	    case 38:
    	        if ((UserY == YMin) && (YMin == 0))
    	            return;
    	        document.getElementById("x"+UserX+"y"+UserY).style.background= "";
    	        UserY--;
    	        if (UserY < YMin)
    	            scroll();
    	        document.getElementById("x"+UserX+"y"+UserY).style.background= UserImage;
    	        break;
    	    case 39:
    	        if ((UserX == XMax) && (XMax == totalWidth))
    	            return;
    	        document.getElementById("x"+UserX+"y"+UserY).style.background= "";
    	        UserX++;
    	        if (UserX > XMax)
    	            scroll();
    	        document.getElementById("x"+UserX+"y"+UserY).style.background= UserImage;
    	        break;
    	    case 40:
    	        if ((UserY == YMax) && (YMax == totalHeight))
    	            return;
    	        document.getElementById("x"+UserX+"y"+UserY).style.background= "";
    	        UserY++;
    	        if (UserY > YMax)
    	            scroll();
    	        document.getElementById("x"+UserX+"y"+UserY).style.background= UserImage;
    	        break;
    	}
    }
    Chaque DIV à un ID spécial qui lui est donné en fonction de 2 variables de position. Si on se déplace à gauche, on enlève le background de la DIV où se trouve le personnage, on change sa position et on affiche son image en background de la nouvelle position (on bouge seulement si on peut, à savoir si on est dans notre damier, sinon on fait une autre action scroll() mais ce n'est pas le problème ici...).

    J'espère que ceci aidera à résoudre mon problème au plus vite.

    Merci d'avance.

  4. #4
    Rédacteur/Modérateur

    Avatar de SpaceFrog
    Homme Profil pro
    Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Inscrit en
    Mars 2002
    Messages
    39 659
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2002
    Messages : 39 659
    Billets dans le blog
    1
    Par défaut
    il est de quelle forme userImage ???
    Ma page Developpez - Mon Blog Developpez
    Président du CCMPTP (Comité Contre le Mot "Problème" dans les Titres de Posts)
    Deux règles du succès: 1) Ne communiquez jamais à quelqu'un tout votre savoir...
    Votre post est résolu ? Alors n'oubliez pas le Tag

    Venez sur le Chat de Développez !

  5. #5
    Expert éminent

    Homme Profil pro
    Inscrit en
    Janvier 2007
    Messages
    13 474
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2007
    Messages : 13 474
    Par défaut
    Tu as essayé avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    document.getElementById("x"+UserX+"y"+UserY).style.backgroundImage= UserImage;
    (background est un réceptacle commun pour toutes les propriétés de background, dont l'image) ?

    A+

  6. #6
    Rédacteur/Modérateur

    Avatar de SpaceFrog
    Homme Profil pro
    Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Inscrit en
    Mars 2002
    Messages
    39 659
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2002
    Messages : 39 659
    Billets dans le blog
    1
    Par défaut
    et userImage est il du format
    Ma page Developpez - Mon Blog Developpez
    Président du CCMPTP (Comité Contre le Mot "Problème" dans les Titres de Posts)
    Deux règles du succès: 1) Ne communiquez jamais à quelqu'un tout votre savoir...
    Votre post est résolu ? Alors n'oubliez pas le Tag

    Venez sur le Chat de Développez !

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

Discussions similaires

  1. [Python 3.X] Evènement onkeydown/up HTML et CGI Python
    Par LeSylf dans le forum Général Python
    Réponses: 0
    Dernier message: 11/10/2014, 19h53
  2. Accès à une case d'un DBGrid dans l'event OnKeyDown
    Par fba dans le forum Bases de données
    Réponses: 2
    Dernier message: 02/03/2004, 12h48
  3. OnKeyDown avec TAB et SHIFT TAB
    Par StarMusic dans le forum Composants VCL
    Réponses: 2
    Dernier message: 18/12/2003, 12h21
  4. Evènement sur clic droit !?
    Par soccersoft dans le forum Composants VCL
    Réponses: 6
    Dernier message: 26/12/2002, 21h39
  5. [Applicatif]OnKeyDown
    Par psl dans le forum Langage
    Réponses: 4
    Dernier message: 28/10/2002, 15h55

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