Алексей Емелин — Технология активных областей в api...

57
Алексей Емелин Инженер по автоматизации тестирования Технология активных областей в API Яндекс.Карт Субботник, Санкт-Петербург , 15 июня 2013 года

Upload: yandex

Post on 15-Jun-2015

708 views

Category:

Documents


7 download

DESCRIPTION

Каждому разработчику известно, что карта, перегруженная интерактивными объектами, создает огромную нагрузку на браузер и замедляет работу сайта. Но что делать, если отображение большого числа объектов, с которыми нужно взаимодействовать, — это не просто прихоть, а основная функциональность сервиса? В API Яндекс.Карт мы реализовали технологию активных областей, которая эффективно решает такие задачи. Доказательством этому являются, например, сервисы Яндекс.Пробки, Яндекс.Фотки на карте, а также многие сторонние сервисы, использующие API наших карт. В докладе рассказывается о том, как именно работает эта технология и как вы можете использовать ее в собственных проектах.

TRANSCRIPT

Page 1: Алексей Емелин — Технология активных областей в API Яндекс.Карт

Алексей Емелин Инженер по автоматизации тестирования

Технология активных областей в API Яндекс.Карт

Субботник, Санкт-Петербург, 15 июня 2013 года

Page 2: Алексей Емелин — Технология активных областей в API Яндекс.Карт

2

Карта

Page 3: Алексей Емелин — Технология активных областей в API Яндекс.Карт

3

Карта с географическим объектом

Page 4: Алексей Емелин — Технология активных областей в API Яндекс.Карт

4

Карта с географическими объектами

Page 5: Алексей Емелин — Технология активных областей в API Яндекс.Карт

5

Карта с географическими объектами

Page 6: Алексей Емелин — Технология активных областей в API Яндекс.Карт

6

Карта с географическими объектами

Page 7: Алексей Емелин — Технология активных областей в API Яндекс.Карт

7

Карта с географическими объектами

Page 8: Алексей Емелин — Технология активных областей в API Яндекс.Карт

8

Кластеры

Page 9: Алексей Емелин — Технология активных областей в API Яндекс.Карт

9

Кластеры

Page 10: Алексей Емелин — Технология активных областей в API Яндекс.Карт

10

Много файлов

Page 11: Алексей Емелин — Технология активных областей в API Яндекс.Карт

11

Не точечные объекты

Page 12: Алексей Емелин — Технология активных областей в API Яндекс.Карт

12

Технология активных областей

Page 13: Алексей Емелин — Технология активных областей в API Яндекс.Карт

13

Технология активных областей

• Картиночный слой • Описания активных областей • Источник данных • Слой активных областей

Page 14: Алексей Емелин — Технология активных областей в API Яндекс.Карт

14

Технология активных областей

Page 15: Алексей Емелин — Технология активных областей в API Яндекс.Карт

15

Технология активных областей

Page 16: Алексей Емелин — Технология активных областей в API Яндекс.Карт

16

Технология активных областей

Page 17: Алексей Емелин — Технология активных областей в API Яндекс.Карт

17

Картиночный слой

Page 18: Алексей Емелин — Технология активных областей в API Яндекс.Карт

18

Картиночный слой

Page 19: Алексей Емелин — Технология активных областей в API Яндекс.Карт

19

Картиночный слой

Page 20: Алексей Емелин — Технология активных областей в API Яндекс.Карт

20

Картиночный слой. How-to

Хотите  зависеть  от  стороннего  

сервиса?  

gmapuploader.com   bit.ly/APIDler  

ДА НЕТ

Page 21: Алексей Емелин — Технология активных областей в API Яндекс.Карт

21

Картиночный слой

• Создается с помощью класса Layer • Для всех уровней масштабирования • Прозрачный фон • Только нужные тайлы

Page 22: Алексей Емелин — Технология активных областей в API Яндекс.Карт

22

Описания активных областей

Page 23: Алексей Емелин — Технология активных областей в API Яндекс.Карт

23

Пример описания JSON объекта активной области:

"data": {! "type": "FeatureCollection",! "features": [{! "type": "Feature",! "properties": {! "hintContent": "содержимое хинта",! "balloonContent": "содержимое балуна",! "HotspotMetaData": {! "id": 10469893,! "RenderedGeometry": {! "type": "Polygon",! "coordinates”:![[[-28, 115], [86, 115], !! ! ! ! ! ! ! ! ! ! ! ! ! ! [200, 19], [-28, 115]]]!

}! } !! ! ! !}!

}]! }!

Описания активных областей

Page 24: Алексей Емелин — Технология активных областей в API Яндекс.Карт

24

Описания активных областей

Page 25: Алексей Емелин — Технология активных областей в API Яндекс.Карт

25

Описания активных областей

тайл [0, 0] тайл [0, 1]

(160, 140)

(160, 396)

(376, 140)

(376, 396)

(120, 140)

(120, 396)

(-96, 140)

(-96, 396)

Page 26: Алексей Емелин — Технология активных областей в API Яндекс.Карт

26

Описания активных областей тайл [0, 0] тайл [0, 1]

тайл [1, 0] тайл [1, 1]

Page 27: Алексей Емелин — Технология активных областей в API Яндекс.Карт

27

Описания активных областей

Пример   Тип  геометрии   Описание  

Rectangle        

Прямоугольник  

Polygon        

Многоугольник  

ConvexPolygon        

Выпуклый  многоугольник  

MulDpolygon        

Сложная  фигура.  Состоит  из  нескольких  многоугольников  

MulDConvexPolygon        

Сложная  фигура.  Состоит  из  нескольких  выпуклых  многоугольников  

Page 28: Алексей Емелин — Технология активных областей в API Яндекс.Карт

28

Описания активных областей

•  JSON • Для всех уровней масштабирования • Уникальные идентификаторы в пределах слоя

• Пиксельные координаты • Строгий тип геометрии • Могут содержать данные

Page 29: Алексей Емелин — Технология активных областей в API Яндекс.Карт

29

Источник данных

Page 30: Алексей Емелин — Технология активных областей в API Яндекс.Карт

30

Источник данных

описания  активных  областей  

источник  данных  

слой  активных  областей  

Page 31: Алексей Емелин — Технология активных областей в API Яндекс.Карт

31

Источник данных

описания  активных  областей  

источник  данных  

слой  активных  областей  

Page 32: Алексей Емелин — Технология активных областей в API Яндекс.Карт

32

Источник данных. JSONP

1.  API формирует callback функцию 2.  API в запросе к серверу передает имя

callback функции 3.  Сервер оборачивает данные в callback функцию, взяв ее имя из запроса

4.  API выполняет callback функцию с полученными от сервера данными

Page 33: Алексей Емелин — Технология активных областей в API Яндекс.Карт

33

Источник данных. JSONP

1.  API формирует callback функцию 2.  API в запросе к серверу передает имя

callback функции 3.  Сервер оборачивает данные в callback функцию, взяв ее имя из запроса

4.  API выполняет callback функцию с полученными от сервера данными

Page 34: Алексей Емелин — Технология активных областей в API Яндекс.Карт

34

Источник данных. JSONP. Шаблоны

1.  API формирует callback функцию по шаблону (callback_%x_%y_%z)

2.  API запрашивает данные от сервера, уже обернутые в функцию заданную по шаблону

3.  API выполняет callback функцию с полученными от сервера данными

Page 35: Алексей Емелин — Технология активных областей в API Яндекс.Карт

35

Источник данных. Бонусы

• Переопределение метода restrict(layer, tileNumber, zoom) для уменьшения числа запросов к серверу (http://bit.ly/APIhotspot)

• Кэширование ответа сервера

Page 36: Алексей Емелин — Технология активных областей в API Яндекс.Карт

36

Источник данных

•  JSONP • Создается с помощью класса ObjectSource • Шаблон пути к данным • Необязательный jsonp-callback • Кэширование

Page 37: Алексей Емелин — Технология активных областей в API Яндекс.Карт

37

Слой активных областей

Page 38: Алексей Емелин — Технология активных областей в API Яндекс.Карт

38

Слой активных областей

Page 39: Алексей Емелин — Технология активных областей в API Яндекс.Карт

39

Технология активных областей

• Картиночный слой • Описания активных областей • Источник данных • Слой активных областей

Page 40: Алексей Емелин — Технология активных областей в API Яндекс.Карт

40

Технология активных областей

Page 41: Алексей Емелин — Технология активных областей в API Яндекс.Карт

41

Технология активных областей

Page 42: Алексей Емелин — Технология активных областей в API Яндекс.Карт

42

Технология активный областей

Page 43: Алексей Емелин — Технология активных областей в API Яндекс.Карт

43

var map = new ymaps.Map('map', {! center: [55.709243, 37.500737],! zoom: 9! }),! imgUrl = 'http://server.domain/images/tiles/%z/%x/%y', ! hotspotUrl = 'http://server.domain/hotspots/%z/tile_%x_%y', ! callback = 'myCallback_%c', ! objSource = new ymaps.hotspot.ObjectSource(hotspotUrl, callback),! hotspotLayer = new ymaps.hotspot.Layer(objSource),! imgLayer = new ymaps.Layer(imgUrlm {tileTransparent: true});!!map.layers.add(hotspotLayer);!map.layers.add(imgLayer);!!

Технология активных областей

Page 44: Алексей Емелин — Технология активных областей в API Яндекс.Карт

44

Технология активных областей. Пробки

Page 45: Алексей Емелин — Технология активных областей в API Яндекс.Карт

45

Технология активных областей. Фотографии

Page 46: Алексей Емелин — Технология активных областей в API Яндекс.Карт

46

Технология активных областей. Поиск

Page 47: Алексей Емелин — Технология активных областей в API Яндекс.Карт

47

Бонус!

Page 48: Алексей Емелин — Технология активных областей в API Яндекс.Карт

48

Технология активных областей

менеджер  хотспотов  

событие  на  карте  

список  контейнеров  

контейнер  шейпов  слоев  

шейп  

шейп  

шейп  

описания  активных  областей  

источник  данных   слой  

Page 49: Алексей Емелин — Технология активных областей в API Яндекс.Карт

49

Технология активных областей

менеджер  хотспотов  

событие  на  карте  

список  контейнеров  

контейнер  шейпов  слоев  

контейнер  шейпов  оверлеев  

шейп  

шейп  

шейп  

описания  активных  областей  

источник  данных   слой  

шейп  

шейп  

шейп  

Page 50: Алексей Емелин — Технология активных областей в API Яндекс.Карт

50

Технология активных областей

Page 51: Алексей Емелин — Технология активных областей в API Яндекс.Карт

51

Сотни географических объектов

Page 52: Алексей Емелин — Технология активных областей в API Яндекс.Карт

52

Тысячи DOM-элементов

3646 DOM-элементов!

document.getElementsByTagName("*").length

Page 53: Алексей Емелин — Технология активных областей в API Яндекс.Карт

53

* не работает в браузерах, не поддерживающих canvas

map.options.set({!!geoObjectOverlayFactory:'default#interactiveGraphics’!

});!

Строка изменившая мир *

Page 54: Алексей Емелин — Технология активных областей в API Яндекс.Карт

54

Сотни географических объектов

Page 55: Алексей Емелин — Технология активных областей в API Яндекс.Карт

55

Сотни DOM-элементов

60 DOM-элементов!

Page 56: Алексей Емелин — Технология активных областей в API Яндекс.Карт

56

Полезные ссылки API

api.yandex.ru/maps

ymapsapi.ya.ru

facebook.com/ymapsapi

Page 57: Алексей Емелин — Технология активных областей в API Яндекс.Карт

Емелин Алексей

Инженер по автоматизации тестирования

+7 (911) 785-42-46

[email protected] twitter:aemelin

Спасибо!