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 :

onmouseover: peut on acceder aux coordonnées du rectangle qui déclenche l'event ?


Sujet :

JavaScript

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juin 2004
    Messages
    25
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2004
    Messages : 25
    Points : 34
    Points
    34
    Par défaut onmouseover: peut on acceder aux coordonnées du rectangle qui déclenche l'event ?
    Voila j'ai un lien :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
     Ceci est un lien <span class="tip" onmouseover="tooltip('csstips');" ><a href="http://www.developpez.com/">MonLienClassique</a>
    </span> le menu tool tip doit apparaite au passage de la souris....<br/>
    Je voudrais connaitre à partir de ma fonction tooltip('csstips'), les coordonnées du rectangle sur lequel s'appuie le navigateur pour déclencher le onmouseover. (j'imagine que les coordonnées de ce meme rectangle doivent etre utilisée pour déclencher un MouseOut).
    Voila . Merci d'avance.

  2. #2
    Expert éminent sénior

    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
    Points : 36 571
    Points
    36 571
    Par défaut
    Bonjour,
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <span class="tip" onmouseover="alert('haut:'+this.style.top+', gauche:'+this.style.left+', largeur:'+this.style.width+', hauteur:'+this.style.height);tooltip('csstips');" >
    A toi de l'utiliser dans la fonction ...

    A+

  3. #3
    Expert confirmé
    Avatar de le_chomeur
    Profil pro
    Développeur informatique
    Inscrit en
    Février 2006
    Messages
    3 653
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 3 653
    Points : 4 835
    Points
    4 835
    Par défaut
    Salut , tu peux utiliser les propriétés :
    offsetLeft et offsetTop de ton objet.

  4. #4
    Expert éminent sénior

    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
    Points : 36 571
    Points
    36 571
    Par défaut
    Citation Envoyé par le_chomeur Voir le message
    Salut , tu peux utiliser les propriétés :
    offsetLeft et offsetTop de ton objet.
    Exact, c'est mieux.
    Sans le préfixe "style." de mon exemple, par contre ...

  5. #5
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juin 2004
    Messages
    25
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2004
    Messages : 25
    Points : 34
    Points
    34
    Par défaut C'est PARFAIT !!!
    Merci, j'ai ramé toute la journée...
    J'utilise this.offsetLeft et ca marche impec.
    Voici le code complet en final. (C'est pour faire du multilien).
    Le code est "cochon" mais il marche bien:
    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
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    176
    177
    178
    179
    180
    181
    182
    183
    184
    185
    186
    187
    188
    189
    190
    191
    192
    193
    194
     
    <?xml version="1.0" encoding="iso-8859-1"?>
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN"
            "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
    <head>
    	<meta http-equiv="content-type" content="text/html; charset=iso-8859-1" />
    	<title>Multi Lien</title>
    	<script type="text/javascript">
    	/*<![CDATA[*/
    		// position of the tooltip relative to the mouse in pixel //
    		var offsetx =0;										  //
    		var offsety =20;										  //
    		var in_mlink = false;
    		function newelement(newid)
    		{ 
    			if(document.createElement)
    			{ 
    				var el = document.createElement('div'); 
    				el.id = newid;     
    				with(el.style)
    				{ 
    					display = 'none';
    					position = 'absolute';
    				} 
    				el.innerHTML = '&nbsp;'; 
    				document.body.appendChild(el); 
    			} 
    		} 
    		var ie5 = (document.getElementById && document.all); 
    		var ns6 = (document.getElementById && !document.all); 
    		var ua = navigator.userAgent.toLowerCase();
    		var isapple = (ua.indexOf('applewebkit') != -1 ? 1 : 0);
    		var tdebug="begin</br>";
    		var oldTypdiv='';
    		var x_element;
    		var y_element;
    		function getmouseposition(e) // thanks to Grant O. Anderson from Arizona State University
    		{
     
    			if(document.getElementById  )
    			{
    				var iebody=(document.compatMode && 	document.compatMode != 'BackCompat') ? 	document.documentElement : document.body;
    				pagex = (isapple == 1 ? 0 : (ie5)?iebody.scrollLeft:window.pageXOffset);
    				pagey = (isapple == 1 ? 0 : (ie5)?iebody.scrollTop:window.pageYOffset);
    				mousex = (ie5)?event.x:(ns6)?clientX = e.clientX:false;
    				mousey = (ie5)?event.y:(ns6)?clientY = e.clientY:false;
    				var elem_tooltip = document.getElementById('tooltip');
    				mx=mousex+pagex;				
    				my=mousey+pagey;
     
     
    				if ( !in_mlink) {
    //					elem_tooltip.style.left = (mousex+pagex+offsetx) + 'px';
    //					elem_tooltip.style.top = (mousey+pagey+offsety) + 'px';
     
    					elem_tooltip.style.left = (x_element+offsetx) + 'px';
    					elem_tooltip.style.top = (y_element+offsety) + 'px';
     
     
       					in_mlink = true;
    					cx=parseInt(elem_tooltip.style.left.replace(/px/,""),10)-offsetx;
    					cy=parseInt(elem_tooltip.style.top.replace(/px/,""),10)-offsety;
    					mydebug('{'+mx+','+my+','+cx+','+cy+' -'+my+'-}');
    				}
    				else {
    					cx=parseInt(elem_tooltip.style.left.replace(/px/,""),10)-offsetx;
    					cy=parseInt(elem_tooltip.style.top.replace(/px/,""),10)-offsety;
    					vx=100;
    					vy=100;
    					tol=15;
    					if (  ( cx <= mx+tol ) && ( mx-tol < cx + vx) &&  (cy <= my+tol  ) && ( my-tol < cy+vy)) { 
    //						mydebug('['+cx +'<='+mx+'<'+(cx+vx)+' && '+cy+'<='+my+'<'+(cy+vy)+' IN]');
    					}
    					else {
    						mydebug('['+cx +'<='+mx+'<'+(cx+vx)+' && '+cy+'<='+my+'<'+(cy+vy)+' OUT]');
    						pmy=my;
    						var iebody=(document.compatMode && 	document.compatMode != 'BackCompat') ? 	document.documentElement : document.body;
    					    var elem_tooltip = document.getElementById('tooltip');
    						document.getElementById('tooltip').style.display = 'none';	
    						in_mlink = false;
    						document.onmousemove = null;
    						oldTypdiv='';
    					} 
     
    				}
     
    			}
    		}
     
    		function tooltip(tipdiv)
    		{
    			if (oldTypdiv==tipdiv) { // cas ou le menu du lien est déja affiché.
    				mydebug('SAME tooltip:'+tipdiv);
    				 return;
    			} else {
    				mydebug('tooltip:'+tipdiv);
    			}
     
     
     
    			if (in_mlink) { // si déja dans lien
    						var iebody=(document.compatMode && 	document.compatMode != 'BackCompat') ? 	document.documentElement : document.body;
    					    var elem_tooltip = document.getElementById('tooltip');
    						document.getElementById('tooltip').style.display = 'none';	
    						in_mlink = false;
    			}
    			oldTypdiv=tipdiv;
    			var tip = document.getElementById(tipdiv).innerHTML;
    			if(!document.getElementById('tooltip')) newelement('tooltip');
    			var elem_tooltip = document.getElementById('tooltip');
    			var par=elem_tooltip.parentNode;
    			elem_tooltip.innerHTML = tip;
    			elem_tooltip.style.display = 'block';
    			document.onmousemove = getmouseposition;
    		}
    		function coordElement(x,y) {
    			mydebug('coor:'+x+' '+y);
    			x_element=x;
    			y_element=y;
    		}
    		function  mydebug(t)
    		{
    //				tdebug=tdebug+t+" ";
    //			    document.getElementById("LBL_pos").innerHTML = tdebug; 
    		}
    		/*]]>*/
    	</script>
     
    	<style type="text/css">
    	/*<![CDATA[*/
     
    		/* style your tooltips here */
    		#tooltip {
    			padding: 3px;
    			background: #f9f9f9;
    			border: 1px solid #eee;
    			text-align: center;
    			font-size: smaller;
    //			opacity: .9;
    		}
     
    		/* style the spans with tooltips here */
    		span.tip {
    			border-bottom: 1px solid #eee;
    		}
     
    		span.tip span {
     
    			display: none;
    		}
     
    		a.syst {
                    color:#555555 ;
                    margin-top:0px ; /* Crée un marge de pixels en te chaque ligne du menu */
                    display:block ;/* menu vertical*/
                    }       
    		a.syst:hover {
    				 color:#000000 ;
                     background-color:#93CDD9;
                   }                	
     
     
    		/*]]>*/
    	</style>
    </head>
    <body>
    	<div id="main">
     
    			<br/><h3>Multiliens sur un lien classique</h3>
    		    Ceci est une démonstation de multi-liens <span class="tip" onmouseover="coordElement(this.offsetLeft,this.offsetTop);tooltip('csstips');" ><a  href="http://www.developpez.com/">Lien 1 classique</a>
    			<span id="csstips" ><a class="syst" href="http://www.developpez.net/forums/">Mon lien 2 (forum)</a>
    				<a class="syst" href="http://general.developpez.com/cours/">Mon Lien 3 (cours)</a>
    				<a class="syst" href="http://xml.developpez.com/sources/">Mon lien 4 (source)</a></span></span>, le menu tool tip doit apparaite au passage de la souris....<br/>
    				Voila une ligne en dessous pour voir ce que ca donne, lorsque le lien est au milieu d'un texte.<br/>		
    				Et ca c'est du blabla pour remplir la ligne.Et ca c'est du blabla pour remplir la ligne.<br/>
    				Et ca c'est du blabla pour remplir la ligne.Et ca c'est du blabla pour remplir la ligne.<br/>
     
     
     
    		    Ceci est une deuxième démonstration de multi-liens <span class="tip" onmouseover="coordElement(this.offsetLeft,this.offsetTop);tooltip('csstips2');" ><a href="http://www.developpez.com/">Lien bis </a>
    			<span id="csstips2"><a class="syst" href="http://www.developpez.net/forums/">Mon lien bis 2 (forum)</a>
    				<a class="syst" href="http://general.developpez.com/cours/">Mon Lien bis 3 (cours)</a>
    				<a class="syst" href="http://xml.developpez.com/sources/">Mon lien bis 4 (source)</a></span></span>, le menu tool tip doit apparaite au passage de la souris....<br/>
    				Voila une ligne en dessous pour voir ce que ca donne, lorsque le lien est au milieu d'un texte.<br/>		
    				Et ca c'est du blabla pour remplir la ligne.Et ca c'est du blabla pour remplir la ligne.<br/>
    				Et ca c'est du blabla pour remplir la ligne.Et ca c'est du blabla pour remplir la ligne.<br/>
     
    		</div>
    			<p id="LBL_pos"></p>
     
     
    </body>
    </html>
    Cela va me permettre d'avancer sur l'implémentation de xlink (voir forum xml pour en finir avec xlink)
    Merci encore.

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

Discussions similaires

  1. [FPDF] Peut on acceder aux donnees avec fpdf ?
    Par jmtrivia dans le forum Bibliothèques et frameworks
    Réponses: 2
    Dernier message: 19/03/2010, 22h45
  2. Réponses: 6
    Dernier message: 04/12/2005, 15h34
  3. [FLASH MX 2004] Acceder aux variables d'une Popup
    Par freegreg dans le forum Flash
    Réponses: 3
    Dernier message: 05/05/2004, 21h13
  4. [Flash MX ]Acceder aux champs d'un Objet
    Par yacinechaouche dans le forum Flash
    Réponses: 3
    Dernier message: 15/04/2004, 17h39
  5. Réponses: 3
    Dernier message: 25/07/2002, 10h42

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