1
我需要在FabricJS画布上启用触控缩放/平移。有一些库允许在图像上发生这种行为(请参阅pinch-zoom-canvas)或通过鼠标点击事件(请参阅this Fiddle),但我似乎无法正确连接“touch:gesture”事件。FabricJS轻触平移/缩放整个画布
我已经建立了手势库启用(所以this FabricJS演示在我本地工作),但我不知道从哪里开始将手势与工作小提琴结合起来。
我想这样的代码变化:
canvas.on({
'touch:gesture': function() {
var text = document.createTextNode(' Gesture ');
info.insertBefore(text, info.firstChild);
// Handle zoom only if 2 fingers are touching the screen
if (event.e.touches && event.e.touches.length == 2) {
// Get event point
var point = new fabric.Point(event.self.x, event.self.y);
// Remember canvas scale at gesture start
if (event.self.state == "start") {
zoomStartScale = self.canvas.getZoom();
}
// Calculate delta from start scale
var delta = zoomStartScale * event.self.scale;
// Zoom to pinch point
self.canvas.zoomToPoint(point, delta);
}
},
'touch:drag': function(e) {
panning = true;
var text = document.createTextNode(' Dragging ');
info.insertBefore(text, info.firstChild);
if (panning && e && e.e) {
debugger;
var units = 10;
var delta = new fabric.Point(e.e.movementX, e.e.movementY);
canvas.relativePan(delta);
}
panning = false;
},
'touch:longpress': function() {
var text = document.createTextNode(' Longpress ');
info.insertBefore(text, info.firstChild);
}
});
但是,当我用iPhone/iPad测试没有任何反应。
真棒!真正为所有面料用户提供了极大的帮助! –
得到了一些问题:我试过这个答案,但我的'帆布'没有收到'touch:gesture',似乎只有物体接收到'touch:gesture'?真的很想知道你的画布如何接收“touch:gesture”事件,谢谢!顺便说一句,我使用1.7.20(带有build_with_gestures)。 –