Usted está aquí

Alternativas para crear Mapas de Google adaptables y asíncronos en Drupal

Escrito por Ing. Maikel Maldonado del Toro, 05 de Abril, del 2017
Mapas-Google-adaptables-asíncronos-Drupal

Los mapas de Google son una buena alternativa para mostrar información importante de contacto en nuestros sitios web. Existen muchas formas de hacerlo incluyendo el uso de módulos.

 

Las principales dificultades que a mi juicio se presentan al utilizar el módulo de Drupal son:

- El Javascript de la petición a gmaps, al ser un js bloquea la carga de la página hasta que no se cargue completamente el fichero.

- El mapa generado no es responsive.

 

Las propuestas que traigo para resolver las anteriores dificultades son:

1- Obtén las coordenadas del lugar que deseas mostrar (recomiendo para esto usar este sitio http://www.map-embed.com/)

2- Crea un bloque y pega el siguiente código, configurando los parámetros.

 

<div id="gmap_canvas" style="height:280px;width:100%;"></div>

<script>

function init_map() {

jQuery(document).ready(function() {

var myOptions = {

//para que cuando pases por arriba con el scroll ni acerque ni aleje la imagen

scrollwheel:false,

//para que no se pueda mover la posición en la que está enfocado el mapa

draggable:false,

//para eliminar algunos controles innecesarios

mapTypeControl:false,

//para establecer el nivel de acercamiento del mapa

zoom: 14,

//para establecer las coordenadas del centro de mapa (lugar que quieres resaltar)

center: new google.maps.LatLng(23.05286541241737, -82.42761864744568),

//para establecer el tipo de mapa (ROADMAP, SATELLITE, HYBRID, TERRAIN)

mapTypeId: google.maps.MapTypeId.ROADMAP

};

//crea el mapa en el elemento que tengo como id "gmap_canvas" (en este ejemplo)

map = new google.maps.Map(document.getElementById("gmap_canvas"), myOptions);

//crea el marcador en el lugar que se quiere destacar

marker = new google.maps.Marker({map: map, position: new google.maps.LatLng(23.05286541241737, -82.42761864744568)});

//Ubica el texto deseado en el marcador

infowindow = new google.maps.InfoWindow({content: "<br/>Lombao Estudios<br/> La Habana, Cuba"});

//evento para abrir el cuadro de texto dando click en el marcador

google.maps.event.addListener(marker, "click", function() {

infowindow.open(map, marker);

});

//para abrir el texto al cargar

infowindow.open(map, marker);

//para lograr que sea responsive

google.maps.event.addDomListener(window, "resize", function() {

var center = map.getCenter();

google.maps.event.trigger(map, "resize");

map.setCenter(center);

});

 

});

}

google.maps.event.addDomListener(window, 'load', init_map);

</script>

<script src="https://maps.googleapis.com/maps/api/js?sensor=false&language=es&callback=init_map" async defer></script>

 

A continuación, te facilito una especie de glosario para la mejor comprensión del trabajo:

//init_map

Es el nombre de la función que se creó al inicio del script.

//con async defer

Es para lograr que la carga sea asíncrona.

En caso de que el sitio sea multilingüe poner en la url del script en lugar de 'language=es' 'language=en'

 

Con esta sencilla guía tienes la ventaja de si usas solo JavaScript y HTML se puede utilizar en el bloque con el filtro fullHTML y no PHPCode, por lo que puede ser cacheado.

 

Saludos, no vemos en el próximo blog, en el cual escribiré sobre: La alternativa de crear un bloque de Facebook adaptable y asíncrono.

JeffreyBew
2020-07-01
Good material. Thank you! what is cbd
Lancesmumb
2020-07-01
Wonderful advice. Regards! bad credit car loans small loan
AbermotLew
2020-07-01
магазины партнеры карты хоум кредит рассрочка в екатеринбурге [url=https://cyberkotleta.ru/rasschitat-srok-viplati-kredita.html]рассчитать срок выплаты кредита[/url] банк девон кредит режим работы как занять гос волну взять кредит 1000000 рублей на 5 лет сколько платить в месяц в сбербанке https://cyberkotleta.ru/credit-one-bank-corporate-office-las-vegas-nv-89113.html кредит под залог квартиры без подтверждения дохода в москве условия
Jameswhoms
2020-07-01
Many thanks, A good amount of postings! [url=https://paydayloansttf.com/]online loans instant approval[/url] personal loans with no credit
AbermotLew
2020-07-01
взять кредит с действующими просрочками [url=https://myface-bulldogs.ru/pressa-onlayn-va-bank-v-krasnodare.html]пресса онлайн ва банкъ в краснодаре[/url] погашение кредитов за счет прибыли игровой системный блок в кредит бик сбербанка по номеру карты как узнать https://myface-bulldogs.ru/kaspiy-bank-otkaz-kredita.html какой банк дает кредит без справок о доходах
Jameswhoms
2020-07-01
Perfectly voiced indeed! . [url=https://paydayloansbbv.com/]loans for bad credit guaranteed approval[/url] payday loans direct lender bad credit
JeffreyBew
2020-07-01
Really tons of terrific facts! cbd heroin addiction
DustinLak
2020-07-01
Incredible loads of valuable information! no credit check payday loans instant approval i need cash now
RobertZeste
2020-07-01
Appreciate it, Lots of advice! loans in minutes cash loans to your door
AbermotLew
2020-07-01
хоум кредит козловская 44 волгоград [url=https://pestmosoblcentr.ru/sberbank-kredit-ipoteka-molodaya-semya.html]сбербанк кредит ипотека молодая семья[/url] мфо займер вход в личный кредиты и займы что это плохая кредитная история за границей https://pestmosoblcentr.ru/zaymi-vsem-bez-otkaza-s-plohoy-kreditnoy-istoriey-segodnya.html как положить деньги на телефон через 900 на свой номер теле2

Páginas