问题描述
我正在使用konvajs创建框,并且可以通过ajax双击并保存到数据库中之后的x,y坐标,这是代码:
layer.on('dblclick','Group',function(evt){
var shape = evt.target;
var bin_code = shape.name();
var miniBox = stage.findOne('#mbx_' + bin_code);
var group = stage.findOne('#grp_'+ bin_code);
$.ajax({
url: '/iwms/_update_bin_coord',type: 'POST',dataType: 'json',data: JSON.stringify({'bin_code':bin_code,'x': group.x(),'y': group.y()}),contentType: "application/json; charset=utf-8",success: function(data){
}
});
layer.draw();
});
保存并重新加载浏览器后,坐标乘以2,因此框未保存在应有的位置。我尝试将x,y除以2,如果我的盒子的初始坐标为0,0则可以工作,但是如果我的盒装初始坐标最初不在0,0中,则group.x()和group.y()给我一个绝对值最后一个坐标的值
解决方法
我现在通过在https://konvajs.org/api/Konva.Node.html中使用absolutePosition()而不是组对象的x()和y()来解决它,因为x()和y()将返回从原始位置更改的距离>