Мне нужно включить сенсорное масштабирование/панорамирование на холсте FabricJS. Существуют библиотеки, которые разрешают такое поведение на изображении (см. pinch-zoom-canvas). или с помощью событий щелчка мыши (см. эту Fiddle), но я не могу понять События touch:gesture подключены правильно.
Я создал библиотеку с включенными жестами (поэтому эта демонстрация 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.
canvas
не получаетtouch:gesture
, кажется, что только объекты получаютtouch:gesture
? Очень хотелось бы знать, как ваш холст получает событиеtouch:gesture
, спасибо! Кстати, я использую 1.7.20 (с build_with_gestures). 13.12.2017