2016-07-16 21 views
4

Ich verwende Konva JS in meinem Projekt. Ich füge eine Form auf einen Knopfklick hinzu, der ziehbar ist. Beim Klicken auf die Form muss ich die X- und Y-Position der Form eingeben. getX und getY Funktionen geben das Original X und Y zurück. Wie kann ich das X und Y nach dem Ziehen aktualisieren.Get X und Y einer Form nach dem Ziehen in Konva JS

Beispielcode unten.

var stage = new Konva.Stage({ 
 
     container: 'canvas', // id of container <div> 
 
     width: 500, 
 
     height:300 
 
    }); 
 
    
 
jQuery("#add-shape").click(function(){ 
 
addShape(); 
 
}); 
 
    
 
var addShape = function(){ 
 
    
 
console.log("add shape"); 
 
    
 
var layer = new Konva.Layer(); 
 
var parentContainer = new Konva.Rect({ 
 
      x: stage.getWidth()/2, 
 
      y: stage.getHeight()/2, 
 
      width: 200, 
 
      height: 60, 
 
      cornerRadius: 10, 
 
      fill: '#ccc' 
 
     }); 
 
     
 
     var smallCircle = new Konva.Circle({ 
 
      x: stage.getWidth()/2 + 200, 
 
      y: stage.getHeight()/2 + 30, 
 
      radius: 15, 
 
      fill: "#F2784B", 
 
      stroke: "white", 
 
      strokeWidth: 2 
 
     }); 
 
     
 
     smallCircle.on('click', function() { 
 
     console.log(this.getX(),this.getY()); 
 
      addArrow(this.getX(),this.getY()); 
 
      //get current X and Y here instead of origina X and Y 
 
     }); 
 
     layer.add(parentContainer); 
 
     layer.add(smallCircle); 
 
     layer.draggable('true'); 
 
     stage.add(layer); 
 
} 
 

 
var addArrow = function(arrowX,arrowY){ 
 
    var connectorLayer = new Konva.Layer(); 
 
\t var connector = new Konva.Arrow({ 
 
      points: [arrowX,arrowY,arrowX+10,arrowY], 
 
      pointerLength: 4, 
 
      pointerWidth: 4, 
 
      fill: 'black', 
 
      stroke: 'black', 
 
      strokeWidth: 2 
 
     }); 
 
    connectorLayer.add(connector); 
 
    stage.add(connectorLayer); 
 
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> 
 
<script src="https://cdn.rawgit.com/konvajs/konva/1.0.2/konva.min.js"></script> 
 
<button id="add-shape"> 
 
     Add shape 
 
     </button> 
 
<div id="canvas"> 
 
     
 
     </div>

Antwort

5

Wenn Sie eine Mausposition erhalten müssen Sie verwenden können:

es
smallCircle.on('click', function() { 
    console.log(stage.getPointerPosition()); 
}); 
+0

bereits gefunden. Danke trotzdem. :) –