Einzelnen Beitrag anzeigen

Angel4585

Registriert seit: 4. Okt 2005
Ort: i.d.N.v. Freiburg im Breisgau
2.199 Beiträge
 
Delphi 2010 Professional
 
#1

JavaScript: Quelle von onmouseover

  Alt 26. Jun 2009, 10:09
Hiho,

ich möchte folgendes erreichen:

ein DIV(roam) in einem anderen DIV(feld)

roam soll einen Bereich in feld markieren, dazu möchte ich irgendwo in feld die maustaste drücken(onmousedown) dann den Mauszeiger bei gedrückter Maustaste wohin ziehen(onmousemove) und beim loslassen der Maustaste(onmouseup) sollen die werte(left,top,right,bottom) von roam gespeichert werden.

jetz hab ich das Problem, das ich nicht immer von linksoben nach rechtsunten die maus ziehe, sondern auch mal andersrum und es dann Konflikte im Handling der aktuellen top und elft Werte gibt.

Folgenden Code hab ich jetzt:


Code:
<html>
    <head>
        <script type="text/javascript" >
            var isDown = false;

            var posLeft = 0;
            var posTop = 0;
            var posRight = 0;
            var posBottom = 0;

            function setRoam(id,left,top,width,height){
                document.getElementById(id).style.left = left;
                document.getElementById(id).style.top = top;
                document.getElementById(id).style.width = width;
                document.getElementById(id).style.height = height;
            }

            function startRoam(evt,id,sender){
                var diffX = 0;
                var diffY = 0;
                if(sender == id){
                    var roamdiv = document.getElementById(sender);
                    diffX = roamdiv.offsetLeft;
                    diffY = roamdiv.offsetTop;                  
                }
                document.getElementById("ausgabe").textContent = sender+"|"+id+"|"+(sender==id)+"|"+(evt.x || evt.layerX)+"+"+diffX +"|"+(evt.y || evt.layerY)+"+"+diffY;
                posLeft=(evt.x || evt.layerX)+diffX;
                posTop=(evt.y || evt.layerY)+diffY;
                posRight=posLeft;
                posBottom=posTop;
                isDown = true;
                setRoam(id,posLeft,posTop,posRight-posLeft,posBottom-posTop);
            }

            function changeRoam(evt,id,sender){
                var diffX = 0;
                var diffY = 0;
                if(sender == id){
                    var roamdiv = document.getElementById(sender);
                    diffX = roamdiv.offsetLeft;
                    diffY = roamdiv.offsetTop;
                }
                document.getElementById("ausgabe").textContent = sender+"|"+id+"|"+(sender==id)+"|"+(evt.x || evt.layerX)+"+"+diffX +"|"+(evt.y || evt.layerY)+"+"+diffY;
                var tempX=(evt.x || evt.layerX)+diffX;
                var tempY=(evt.y || evt.layerY)+diffY;
                if(tempX>=posLeft){
                    posRight = tempX;
                }else{
                    posRight=posLeft;
                    posLeft = tempX;
                }
                if(tempY>=posTop){
                    posBottom=tempY;
                }else{
                    posBottom=posTop;
                    posTop = tempY;
                }
                if(isDown){
                    setRoam(id,posLeft,posTop,posRight-posLeft,posBottom-posTop);
                }
            }

            function endRoam(evt,id){
                if(isDown){
                    setRoam(id,posLeft,posTop,posRight-posLeft,posBottom-posTop);
                }
                isDown=false;
            }

        </script>
    </head>
    <body>
        <table>
            <tr>
                <td>
                    <div id="ausgabe" style="position:absolute;top:100px;left:10px;width:200px;height:50px;"></div>
                    <div id="feld1"
                        style="
                        background-image:url(feld.jpg);
                        position:absolute;
                        left:200px;
                        top:200px;
                        width:400px;
                        height:300px;"
                        onmousedown="startRoam(event,'roam1','feld1');"
                        onmousemove="changeRoam(event,'roam1','feld1');"
                        onmouseup="endRoam(event,'roam1');">
                    <div
                        style="position:absolute; top:210px;left:210px;height:50px;width:40px;background:red"
                        id="roam1"
                        onmousedown="startRoam(event,'roam1','roam1');"
                        onmousemove="changeRoam(event,'roam1','roam1');"
                        onmouseup="endRoam(event,'roam1');"></div>

                    </div>

                </td>
                <td></td>
            </tr>
        </table>
    </body>
</html>
Das Problem: Obwohl ich mitm Mauszeiger über roam fahre, wird das onmousemove-Ereignis von feld ausgelöst. Ich bekomme zwar im Handler die Top und left Werte von roam, aber beim sender steht feld drin. Woran liegt das, bzw wie kann ich das beheben?

Hoffe mir kann hier jemand helfen
Martin Weber
Ich bin ein Rüsselmops
  Mit Zitat antworten Zitat