Особенности работы с картами Google через WebKit на платформе 16

Публикация № 1273033

Разработка - Системная интеграция - Интеграция с WEB

WebKit google карты

При переходе на 16 платформу появилась проблема с google картами. Перестали работать вызовы функций JS Поля HTML документа и Callback вызовы в контекст формы из java script Поля HTML документа.

 Проблема вызова JS функций из модуля формы была решена следующим образом:

Функция DOMWindow(Элемент)
    
    Document = Элемент.Документ;
    Если Document.parentWindow = Неопределено Тогда
        Возврат Document.defaultView;
    Иначе
        Возврат Document.parentWindow;
    КонецЕсли; 
    
КонецФункции

Вызов функции определения адреса стал выглядеть вот так

DOMWindow(Элементы.Карта).GeocodeByAddress(Объект.Адрес);

 В JS была следующая функция:

function GeocodeByAddress(address) {
    geocoder.geocode({
        'address': address
    }, function (results, status) {
        if (status == google.maps.GeocoderStatus.OK) {
            for (var i in results) {
                 Form1C.UpdateGeoCode(results[i].geometry.location.lat(), results[i].geometry.location.lng());  
            }
        }
    });
}

Функция GeocodeByAddress отрабатывает асинхронно и по мере выполнения вызывает процедуру UpdateGeoCode формы

В Форме следующая Процедура:

Процедура UpdateGeoCode(Lat, Lng)
    //Что то сделать с координатами    
КонецПроцедуры

И вот здесь я столкнулся с проблемой вызова Процедуры формы. Из за того что Поле HTML документа больше не OLE объект, форму никак не передать в контекст JS. (Можно передать простые типы)

Из- за отсутствия решения пришлось применять кривоватый метод:
Записывать результаты  GeocodeByAddress во внутренние тэги поля HTML документа и опрашивать их с помощью ПодключитьОбработчикОжидания

Вот так стала выглядеть GeocodeByAddress

function GeocodeByAddress(address) {
    document.getElementById('satus_location').innerHTML = "IN PROGRESS";
    geocoder.geocode({
        'address': address
    }, function (results, status) {
        if (status == google.maps.GeocoderStatus.OK) {
            for (var i in results) {
                document.getElementById('CenterLat').innerHTML = results[i].geometry.location.lat();
                document.getElementById('CenterLng').innerHTML = results[i].geometry.location.lng();
            }

            document.getElementById('satus_location').innerHTML = "READY";
        } else {
            document.getElementById('satus_location').innerHTML = "ERROR";
        }
    });
}

Все изложенное присутствует в обработке, реализованной на управляемой форме. Конфигурация базы не имеет значения,  версия платформы 8.3. Был бы рад за советы по реализации Callback функций. Нигде не смог найти.

Для полноценной работы обработки требуется API ключ google, без него работает только установка маркера по координатам и координаты по маркеру. Ключ необходимо ввести в поле API Key (если ключ неверный то карта перестает функционировать совсем). Для получения координат по адресу необходимо набрать произвольный адрес и нажать кнопку Установить метку по адреу. Для установки метки по координатам указать вручную координаты и нажать кнопку Установить конпку по координатам

Обработка выполняет следующие действия с картой:

  1. Определение координат и установка маркера по адресу. 
  2. Установка маркера по координатам
  3. Получение координат по двойному щелчку мыши на карте

Протестировано на платформах 8.3.12.1529, 8.3.16.1502

Скачать файлы

Наименование Файл Версия Размер
Особенности работы с картами Google через WebKit на платформе 16:

.epf 10,45Kb
31.07.20
0
.epf 10,45Kb Скачать

Специальные предложения

Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. t278 35 04.08.20 02:26 Сейчас в теме
у меня с Яндекс картами, после второго или последующего массового вывода меток зависает 1С.
Возможно ваше описание поможет найти решение, но пока нет времени.
Оставьте свое сообщение

См. также

daСклонение: склонение ФИО, должностей, чисел, прилагательных, существительных на языке 1С + ТестЦентр Промо

Универсальные функции v8 1cv8.cf Абонемент ($m)

Функция предназначена для склонения выражений, которые часто требуется при формировании печатных форм договоров и прочих печатных форм. Функция склоняет по падежам ФИО, должности, числительные, валюты, единицы измерения, предметы. Также функция склоняет глаголы и прилагательные по числам и родам и существительные по числам. Имеется режим определения рода переданного выражения. Поддержка форматной строки для вывода результата. Функция не использует внешние библиотеки и веб-сервисы, написана на чистом языке 1С, и поэтому легко встраивается в любую конфигурацию или внешнюю обработку. Правила склонения оформлены в виде таблицы и могут быть легко изменены при необходимости.

1 стартмани

14.02.2015    102116    97    daMaster    90    

Сравнение реального дохода со средним доходом из API.HH.RU

Зарплата Управленческие v8 v8::СПР ЗУП3.x УУ Абонемент ($m)

Внешняя обработка на управляемой форме для 1С:Предприятие 8.3 по интеграции с HH.RU используя HH REST API. Ключевые функции: получение списка вакансий по должностям (Ключ для работы не нужен); расчет среднего дохода; Тестирование проводилось на платформе 1С:Предприятие 8.3 (8.3.13.1513) Зарплата и управление персоналом, редакция 3.1 (3.1.11.68) совместно с API.HH.RU.

1 стартмани

11.11.2019    3956    4    solaru    2    

Конфигурация для рекламного агентства

Управление услугами и сервисом Управление взаимоотношениями с клиентами (СRM) Производство готовой продукции (работ, услуг) Управление взаимоотношениями с клиентами (СRM) Производство готовой продукции (работ, услуг) v8 Реклама, PR и маркетинг УУ Абонемент ($m)

Данная конфигурация выполнена для решения тестового задания: Цель задания: 1) Понять, на каком из клиентов сколько мы заработали;  2) Понять, по какому виду СМИ сколько мы заработали;  3) Проследить по каждой услуге: у кого за сколько купили и кому за сколько продали, с возможностью перейти в соответствующий документ. Реализовано с помощью: 1. Справочники - контрагенты, номенклатура 2. Документы - Поступление услуг, реализация услуг 3. Отчеты - отчет по контрагентам, номенклатуре и движений.

1 стартмани

21.05.2019    4615    0    solaru    0    

Загрузка номенклатуры в УТ 10.3 из Excel файла с генерацией штрихкодов

Загрузка и выгрузка в Excel Обработка справочников Оптовая торговля Розничная торговля Учет ТМЦ Оптовая торговля Розничная торговля Учет ТМЦ v8 УТ10 Россия Абонемент ($m)

Обработка позволяет генерировать новые номенклатурные позиции на основе данных из файла Excel с последующей генерацией штрихкодов (ШК). Может быть полезна при больших поступлениях товаров на склад, где ручное создание и присваивание штрихкода  (ШК) может занимать много времени.

1 стартмани

24.03.2017    7828    7    solaru    0    

Под капотом управляемых форм

Практика программирования v8 1cv8.cf Бесплатно (free)

Управляемые формы уже давно и плотно вошли в жизнь 1С-разработчика. Однако, судя по недавним публикациям на Инфостарте, многие до сих пор мало знакомы с ними. Предлагаю разобраться с тем, что же это такое.

26.08.2013    265576    Evil Beaver    266    

[NotaBene] Универсальный отчет по таблице значений

Практика программирования v7.7 1cv7.md Россия Абонемент ($m)

1C v.7.7 Готовое решение. Не требует настройки. Не требует допрограммирования. Данная обработка решает часто встречающуюся задачу вывода в "красивом" виде таблицы значений (полученной, например, из запроса). Поддерживается произвольное группирование данных, отключение/включение группировок, в т.ч и создание "шахматок" (типа "продажи понедельно"). Обработка может использоваться как и в отладочных целях (для нормального просмотра ТЗ), так и в составе вполне рабочих отчетов. По крайней мере, я неоднократно клиентам данную обработку ставил вместо того, чтобы каждый раз писать замороченные выводы данных. И клиенты довольны, и мне - проще...

2 стартмани

07.05.2007    28820    3    CheBurator    63