{"id":8118,"date":"2019-04-09T07:30:14","date_gmt":"2019-04-09T10:30:14","guid":{"rendered":"http:\/\/www.fernandoquadro.com.br\/html\/?p=8118"},"modified":"2020-09-04T17:05:27","modified_gmt":"2020-09-04T20:05:27","slug":"introducao-ao-leaflet-adicionando-link-parte-10","status":"publish","type":"post","link":"https:\/\/www.fernandoquadro.com.br\/html\/2019\/04\/09\/introducao-ao-leaflet-adicionando-link-parte-10\/","title":{"rendered":"Introdu\u00e7\u00e3o ao Leaflet \u2013 Adicionando link"},"content":{"rendered":"<p>Nesta postagem, adicionaremos um link ao pop-up que exibir\u00e1 a visualiza\u00e7\u00e3o de sat\u00e9lite no Google Maps. A API para trabalhar com URLs do Google Maps pode ser encontrada aqui: <a href=\"https:\/\/developers.google.com\/maps\/documentation\/urls\/guide\" rel=\"noopener noreferrer\" target=\"_blank\">https:\/\/developers.google.com\/maps\/documentation\/urls\/guide<\/a>.<\/p>\n<p><strong>1. Adicionando link na pop-up<\/strong><\/p>\n<p>Para adicionar um link para marcador no pop-up, modificamos o c\u00f3digo JavaScript que cria a camada:<\/p>\n<pre>\r\nvar&nbsp;towns&nbsp;=&nbsp;L.geoJSON(trail_stops,&nbsp;\r\n&nbsp;&nbsp;{pointToLayer:&nbsp;function(feature,&nbsp;latlng){\r\n&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return&nbsp;L.circleMarker(latlng,&nbsp;{radius:&nbsp;5,&nbsp;color:&nbsp;'#00008b',\r\n&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;fillOpacity:&nbsp;0.5});\r\n&nbsp;&nbsp;},\r\n&nbsp;&nbsp;onEachFeature:&nbsp;function(&nbsp;feature,&nbsp;layer){\r\n&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;var&nbsp;townName&nbsp;=&nbsp;feature.properties.name;\r\n&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;var&nbsp;elevation&nbsp;=&nbsp;feature.properties.elev_in_m;\r\n&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;var&nbsp;lat&nbsp;=&nbsp;feature.properties.prim_lat_d;\r\n&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;var&nbsp;lon&nbsp;=&nbsp;feature.properties.prim_lon_1;\r\n&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;var&nbsp;url&nbsp;=&nbsp;'https:\/\/www.google.com\/maps\/@?api=1&map_action=map&center='&nbsp;+&nbsp;\r\n&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;lat&nbsp;+&nbsp;','&nbsp;+&nbsp;lon&nbsp;+&nbsp;'&zoom=15&basemap=satellite';\r\n&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;layer.bindPopup('Name:&nbsp;<a&nbsp;href=\"'&nbsp;+&nbsp;url&nbsp;+&nbsp;'\"&nbsp;target=\"trail_stop\">'&nbsp;+&nbsp;\r\n&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;townName&nbsp;+&nbsp;'<\/a>'&nbsp;+&nbsp;'<br\/>'&nbsp;+\r\n&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;'<br\/>Elevation:&nbsp;'&nbsp;+&nbsp;elevation&nbsp;+\r\n&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;'<br\/>Lat\/Lon:&nbsp;'&nbsp;+&nbsp;lat&nbsp;+&nbsp;'&nbsp;,&nbsp;'&nbsp;+&nbsp;lon);\r\n&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;layer.on('mouseover',&nbsp;function()&nbsp;{layer.openPopup();});\r\n&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;\/\/layer.on('mouseout',&nbsp;function()&nbsp;{layer.closePopup();});\r\n&nbsp;&nbsp;}\r\n&nbsp;&nbsp;});\r\n<\/pre>\n<p>As linhas 11 e 12 configuram o URL. Quando constru\u00eddo no loop <em>onEachFeature<\/em>, um exemplo se parece com isto:<\/p>\n<p><a href=\"https:\/\/www.google.com\/maps\/@?api=1&#038;map_action=map\u00a2er=61.1158333,-146.2663889&#038;zoom=10&#038;basemap=satellite\" rel=\"noopener noreferrer\" target=\"_blank\">https:\/\/www.google.com\/maps\/@?api=1&#038;map_action=map\u00a2er=61.1158333,-146.2663889&#038;zoom=10&#038;basemap=satellite<\/a><\/p>\n<p>Esta URL far\u00e1 com que o mapa centralize a vis\u00e3o nas coordenadas dadas com um n\u00edvel de zoom de 15. O par\u00e2metro <em>basemap=satellite<\/em> ajusta o mapa a uma vis\u00e3o sat\u00e9lite. Outras op\u00e7\u00f5es s\u00e3o roadmap (o padr\u00e3o) e terrain.<\/p>\n<p>Nas linhas 13 a 14, o link \u00e9 constru\u00eddo usando a URL base e os dados de coordenadas de nossa camada. A parte Elevation e Lat \/ Lon definadas para a pop-up permanecem inalteradas.<\/p>\n<p>A linha 18 \u00e9 comentada para fazer o pop-up ficar vis\u00edvel quando o mouse \u00e9 movido. Isso nos permite clicar no link. O pop-up permanece at\u00e9 que outro receba o evento <em>mouseover<\/em> ou voc\u00ea o feche clicando no \u201cx\u201d.<\/p>\n<p><center><br \/>\n<img loading=\"lazy\" decoding=\"async\" src=\"http:\/\/www.fernandoquadro.com.br\/html\/wp-content\/uploads\/2019\/04\/leaflet_map10.png\" alt=\"\" width=\"710\" height=\"711\" class=\"aligncenter size-full wp-image-8122\" srcset=\"https:\/\/www.fernandoquadro.com.br\/html\/wp-content\/uploads\/2019\/04\/leaflet_map10.png 710w, https:\/\/www.fernandoquadro.com.br\/html\/wp-content\/uploads\/2019\/04\/leaflet_map10-150x150.png 150w, https:\/\/www.fernandoquadro.com.br\/html\/wp-content\/uploads\/2019\/04\/leaflet_map10-300x300.png 300w, https:\/\/www.fernandoquadro.com.br\/html\/wp-content\/uploads\/2019\/04\/leaflet_map10-144x144.png 144w, https:\/\/www.fernandoquadro.com.br\/html\/wp-content\/uploads\/2019\/04\/leaflet_map10-600x601.png 600w\" sizes=\"auto, (max-width: 710px) 100vw, 710px\" \/><br \/>\n<\/center><\/p>\n<p><strong>2. C\u00f3digo<\/strong><\/p>\n<p>Para baixar o c\u00f3digo descrito acima, <a href=\"http:\/\/www.fernandoquadro.com.br\/html\/wp-content\/uploads\/2019\/04\/leaflet_day10.zip\" rel=\"noopener noreferrer\" target=\"_blank\">clique aqui<\/a>.<\/p>\n<p><strong>3. YouTube<\/strong><\/p>\n<p>Voc\u00ea pode tamb\u00e9m assistir o que foi apresentado nesse post no YouTube:<\/p>\n<p><center><br \/>\n<iframe loading=\"lazy\" width=\"560\" height=\"315\" src=\"https:\/\/www.youtube.com\/embed\/ieO7mqMj3kg\" frameborder=\"0\" allow=\"accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture\" allowfullscreen><\/iframe><br \/>\n<\/center><\/p>\n","protected":false},"excerpt":{"rendered":"<p>Nesta postagem, adicionaremos um link ao pop-up que exibir\u00e1 a visualiza\u00e7\u00e3o de sat\u00e9lite no Google Maps. A API para trabalhar com URLs do Google Maps pode ser encontrada aqui: https:\/\/developers.google.com\/maps\/documentation\/urls\/guide. 1. Adicionando link na pop-up Para adicionar um link para&#8230; <a class=\"more-link\" href=\"https:\/\/www.fernandoquadro.com.br\/html\/2019\/04\/09\/introducao-ao-leaflet-adicionando-link-parte-10\/\">Continue Reading &rarr;<\/a><\/p>\n","protected":false},"author":275,"featured_media":8119,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[24],"tags":[140,293],"class_list":["post-8118","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-gis","tag-javascript","tag-leaflet"],"_links":{"self":[{"href":"https:\/\/www.fernandoquadro.com.br\/html\/wp-json\/wp\/v2\/posts\/8118","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.fernandoquadro.com.br\/html\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.fernandoquadro.com.br\/html\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.fernandoquadro.com.br\/html\/wp-json\/wp\/v2\/users\/275"}],"replies":[{"embeddable":true,"href":"https:\/\/www.fernandoquadro.com.br\/html\/wp-json\/wp\/v2\/comments?post=8118"}],"version-history":[{"count":9,"href":"https:\/\/www.fernandoquadro.com.br\/html\/wp-json\/wp\/v2\/posts\/8118\/revisions"}],"predecessor-version":[{"id":8948,"href":"https:\/\/www.fernandoquadro.com.br\/html\/wp-json\/wp\/v2\/posts\/8118\/revisions\/8948"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/www.fernandoquadro.com.br\/html\/wp-json\/wp\/v2\/media\/8119"}],"wp:attachment":[{"href":"https:\/\/www.fernandoquadro.com.br\/html\/wp-json\/wp\/v2\/media?parent=8118"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.fernandoquadro.com.br\/html\/wp-json\/wp\/v2\/categories?post=8118"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.fernandoquadro.com.br\/html\/wp-json\/wp\/v2\/tags?post=8118"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}