Есть svg документ схемы зала на 5 000 мест, каждое место представляет собой circle с некоторым набором параметров (место, ряд, класс). Сам зал разбит на секции, соответственно в документе каждый набор точек лежит в контейнере , соответствующий названию сектора.
Сам svg добавляется на сайт в картинкой, а через JS-скрипт (который используется для возможности применять ховер-эффекты иконкам) разворачивается в код:
jQuery('img.svg').each(function(){
var $img = jQuery(this);
var imgID = $img.attr('id');
var imgClass = $img.attr('class');
var imgURL = $img.attr('src');
jQuery.get(imgURL, function(data) {
// Get the SVG tag, ignore the rest
var $svg = jQuery(data).find('svg');
// Add replaced image's ID to the new SVG
if(typeof imgID !== 'undefined') {
$svg = $svg.attr('id', imgID);
}
// Add replaced image's classes to the new SVG
if(typeof imgClass !== 'undefined') {
$svg = $svg.attr('class', imgClass+' replaced-svg');
}
// Remove any invalid XML tags as per http://validator.w3.org
$svg = $svg.removeAttr('xmlns:a');
// Replace image with new SVG
$img.replaceWith($svg);
}, 'xml');
});
Сам svg документ находится уже в контейнере, который обрабатывается скриптом:
panzoom.js. То есть появляется возможность перетаскивать этот свг в самом блоке и соответственно выбирать нужные места.
Проблема заключается в том, что при перетаскивании сильно напрягается браузер (понятно что такой документ надо отрисовывать). Само перетаскивание работает через css свойство matrix(), но оно действует только на документ в целом.
Хотелось бы более плавной работы с такой схемой (есть возможность ее еще приближать и отдалять).
Как я понимаю есть два варианта:
1. Каким-то образом сжать документ. Возможно просто весь код поместить в одну строку. Воспользоваться оптимизаторами, но они удаляют очень важные дата-поля у точек, что критично.
2. Грузить только видимую область документа в блоке, все что пользователь не видит - не грузить, но не представляю себе как это можно реализовать.
Пример для понимания: