Answer the question
In order to leave comments, you need to log in
How to optimize an svg file that has 5,000 points for embedding on a page?
Есть 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');
});
Answer the question
In order to leave comments, you need to log in
1. Растеризовать SVG в обычную картинку. Вынести все данные в отдельный объект с картой. Слушать mouseover обычным VanillaJS.
2. Оптимизировать SVG.
Из этого
Вот в это
Забыть нахрен про jQuery, зумить через CSS, двигать через VanillaJS requestAnimationFrame.
С сервера загружать с gzip.
3. Посмотрите, как это сделано на ticketmaster.com. Там карта разбита на зоны. Можно сделать точно также, но по клику по зоне показывать карту зоны. Т.е. сделать 2 уровня зума. Просто и функционально, плюс можно подсвечивать занятые места.
Браузеру тяжеловато отрисовываеть такое количество элементов.
Canvas вместо SVG не рассматривали?
Я думаю вам нужно разбить ваш svg на несколько, по зонам. Тогда все будет ок.
Сделать один базовый, без конкретных мест, а только с условным обозначением основных зон (VIP-Партер, Партер и тп), а далее уже показывать svg только выбранной зоны. Думаю все будет ок в этом случае.
Didn't find what you were looking for?
Ask your questionAsk a Question
731 491 924 answers to any question