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 :

Afficher les coordonnées d'un layer dans des champs texte


Sujet :

JavaScript

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé Avatar de renaud26
    Homme Profil pro
    Webmaster
    Inscrit en
    Mars 2003
    Messages
    1 365
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Mars 2003
    Messages : 1 365
    Par défaut Afficher les coordonnées d'un layer dans des champs texte
    Bonjour à tous,

    Je rame lamentablement, malgré des tas de recherche. Je voudrais afficher les coords X et Y d'un layer draggable sur une image dans des champs texte nommés X et Y. Voici comment j'ai fait, mais les coordonnées sont fausses...

    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
     
     
    function twPositionRelative(evt) {
    var nOffsetX;
    var nOffsetY;
    evt = (evt) ? evt : ((window.event) ? window.event : "");
    if (evt) {
    if (document.all) {
    nOffsetX = evt.offsetX;
    nOffsetY = evt.offsetY;
    } else if (document.getElementById) {
    nOffsetX = evt.pageX - document.getElementById("monID").offsetLeft;
    nOffsetY = evt.pageY - document.getElementById("monID").offsetTop;
    }
    //monID est le calque draggable dont je veux les coordonnées
     
      document.all.X1.innerText = nOffsetX; //input X
      document.all.Y1.innerText = nOffsetY; //input Y
     
    }
    }
     
    function twInit() {
    var oImage = document.getElementById("image")//le calque de l'image
    if (oImage) {
    oImage.onmousemove = twPositionRelative;
    }
    }
    la fonction twInit() se charge avec body
    les 2 inputs text X et Y sont ok: les coords s'affichent bien, mais erronées

    les layers :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    <img src="image.gif" width="468" height="60" id="image">
    <div id="monID" class="zone">TEXTE</div>
    <script type="text/javascript" language="javascript">
    document.getElementById("monID").style.cursor = 'move';
    new Draggable('monID',{}); 
    </script>
    Vous voyez ce qui cloche ?
    Je veux bien un coup de main...merci !

  2. #2
    Membre Expert
    Avatar de FremyCompany
    Profil pro
    Étudiant
    Inscrit en
    Février 2006
    Messages
    2 532
    Détails du profil
    Informations personnelles :
    Âge : 34
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2006
    Messages : 2 532
    Par défaut
    pk ne pas utiliser this.offsetTop/offsetLeft ?

  3. #3
    Membre éprouvé Avatar de renaud26
    Homme Profil pro
    Webmaster
    Inscrit en
    Mars 2003
    Messages
    1 365
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Mars 2003
    Messages : 1 365
    Par défaut
    Ben en faisant ça, c'est ce que je pensais faire...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
     
    nOffsetX = evt.pageX - document.getElementById("monID").offsetLeft;
    nOffsetY = evt.pageY - document.getElementById("monID").offsetTop;
    Non ?

  4. #4
    Membre éprouvé

    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    1 448
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2006
    Messages : 1 448
    Par défaut
    Elles sont éronnées comment tes valeurs ?

    Si tu les calcules après le déplacement, les offest sont les valeurs à afficher et non pas mouseX - offsetLeft et mouseY - offsetTop (qui te dooneront alors forcement des valeurs constantes).

    PS : Les offset peuvent avoir a être calculer en fonction des conteneurs ancêtres.

  5. #5
    Membre éprouvé Avatar de renaud26
    Homme Profil pro
    Webmaster
    Inscrit en
    Mars 2003
    Messages
    1 365
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Mars 2003
    Messages : 1 365
    Par défaut
    pas facile à dire comment les valeurs sont erronées...
    Et oui, je veux que le user puisse déplacer le layer sur l'image, puis lorsque il lâche le bouton de la souris, cela "fige" X et Y dans les inputs...

  6. #6
    Membre Expert
    Avatar de FremyCompany
    Profil pro
    Étudiant
    Inscrit en
    Février 2006
    Messages
    2 532
    Détails du profil
    Informations personnelles :
    Âge : 34
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2006
    Messages : 2 532
    Par défaut
    pageX n'est pas reconnu par tous les navigateurs.... si ?

Discussions similaires

  1. Réponses: 3
    Dernier message: 24/04/2014, 17h46
  2. récupérer les dates de mysql et les mettre dans des champs textes
    Par abdelkarim_1987 dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 18/10/2013, 14h56
  3. Réponses: 1
    Dernier message: 09/03/2009, 12h01
  4. Réponses: 2
    Dernier message: 13/10/2008, 14h39
  5. [VBA-E] afficher les données d'une datagrid dans des zones de textes
    Par fadwa dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 12/05/2006, 13h51

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