这是我在 Canvas 上移动文本的代码:
paper
.text(self.x, self.y, "Jeaaaaaaaaaaaaaaah")
.attr({
fill: "#000",
dy: 0,
dx: 0,
font: "italic 20px Helvetica"
})
.drag(
function(dx, dy) {
this.attr({x: self.x + dx, y: self.y + dy, dy:0, dx:0});
},
function () {
this.attr({x: self.x, y: self.y, dy:0, dx:0});
},
function () {
self.x = this.attr("x");
self.y = this.attr("y");
}
);
它的工作原理是我可以四处拖动文本,但前两次我四处拖动它的位置完全错误。
这是由这个给出的:
<text ....><tspan style="-webkit-tap-highlight-color: rgba(0, 0, 0, 0);" dy="120">Jeaaaaaaaaaaaaaaah</tspan></text>
前两次拖放之后就变成了
<text ....><tspan style="-webkit-tap-highlight-color: rgba(0, 0, 0, 0);" dy="8.9734">Jeaaaaaaaaaaaaaaah</tspan></text>
它现在可以拖动,并且可以移动到准确的位置。有人知道如何避免这种情况吗?
最佳答案
我遇到了类似的问题,最终手动更改了 tspan 的 dy 属性:
$('tspan').removeAttr('dy').attr('dy', 9);
当然它会改变所有的 tspan ty 属性。
关于javascript - Raphael 在屏幕上拖动文本并 tspan dy,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15913742/