{"id":5154,"date":"2016-05-03T07:10:17","date_gmt":"2016-05-03T10:10:17","guid":{"rendered":"http:\/\/www.fernandoquadro.com.br\/html\/?p=5154"},"modified":"2019-07-04T15:57:55","modified_gmt":"2019-07-04T18:57:55","slug":"como-criar-sua-camada-a-partir-do-openstreetmap","status":"publish","type":"post","link":"https:\/\/www.fernandoquadro.com.br\/html\/2016\/05\/03\/como-criar-sua-camada-a-partir-do-openstreetmap\/","title":{"rendered":"Como criar sua camada a partir do OpenStreetMap"},"content":{"rendered":"<p>O site <a href=\"http:\/\/openstreetmapdata.com\/\" target=\"_blank\" rel=\"noopener noreferrer\">OpenStreetMap Data<\/a> disponibiliza camadas dos continentes, oceano, entre outras. Estas informa\u00e7\u00f5es s\u00e3o bastante utilizadas em qualquer mapa como base, mas dependendo do caso, ter a camada completa n\u00e3o \u00e9 interessante.<\/p>\n<p>Por isso, vamos ensinar como voc\u00ea pode baixar esse dado e realizar o recorte (clipe) apenas da informa\u00e7\u00e3o que deseja. Neste exemplo vamos utilizar o arquivo de oceano para poder explicar como realizar o procedimento.<\/p>\n<p>Baixe o arquivo de pol\u00edgonos do oceano completo, que est\u00e1 dispon\u00edvel em <a href=\"http:\/\/openstreetmapdata.com\/data\/water-polygons\" target=\"_blank\" rel=\"noopener noreferrer\">http:\/\/openstreetmapdata.com\/data\/water-polygons<\/a><\/p>\n<p>Importe o arquivo em uma base de dados PostgreSQL, com o nome<strong> ocean_all<\/strong>, para que possamos recortar no tamanho desejado no banco de dados:<\/p>\n<pre>shp2pgsql -s 4326 -I -D water_polygons.shp ocean_all | osm psql<\/pre>\n<p>Para realizar o recorte da tabela <strong>ocean_all<\/strong> voc\u00ea deve utilizar o SQL descrito abaixo. Para voc\u00ea entender melhor, ele primeiro calcula a extens\u00e3o da \u00e1rea de trabalho (extent), em seguida, usa essa medida para o recorte da tabela completa (com dados de todo o mundo), criando uma nova tabela denominada <strong>ocean<\/strong>, apenas com os dados locais.<\/p>\n<pre>CREATE TABLE ocean AS\r\nWITH bounds AS (\r\n  SELECT ST_SetSRID(ST_Extent(way)::geometry,4326) AS geom\r\n  FROM planet_osm_line\r\n  )\r\nSELECT 1 AS id, ST_Intersection(b.geom, o.geom) AS geom\r\nFROM bounds b, ocean_all o\r\nWHERE ST_Intersects(b.geom, o.geom);<\/pre>\n<p>Note que utilizei informa\u00e7\u00f5es da tabela planet_osm_line, esta tabela encontra-se no post &#8220;<a href=\"http:\/\/www.fernandoquadro.com.br\/html\/2016\/05\/02\/publicando-mapa-com-dados-do-openstreetmap-parte-1\/\" target=\"_blank\" rel=\"noopener noreferrer\">Publicando mapa com dados do OpenStreetMap (Parte 1)<\/a>&#8221; deste blog.<\/p>\n<p>Caso voc\u00ea n\u00e3o tenha esta tabela, voc\u00ea pode usar uma outra que tenha o extent da regi\u00e3o selecionada ou criar o pol\u00edgono em hora de execu\u00e7\u00e3o e substitui o trecho abaixo:<\/p>\n<pre>ST_Extent(way)::geometry<\/pre>\n<p>Por:<\/p>\n<pre>SELECT ST_GeomFromText('POLYGON((-71.1776585052917 42.3902909739571,-71.1776820268866 42.3903701743239,\r\n-71.1776063012595 42.3903825660754,-71.1775826583081 42.3903033653531,-71.1776585052917 42.3902909739571))');<\/pre>\n<p>Lembrando que as coordenadas tem que ser substitu\u00eddas pelas coordenadas que representam a sua \u00e1rea de influ\u00eancia.<\/p>\n","protected":false},"excerpt":{"rendered":"<p>O site OpenStreetMap Data disponibiliza camadas dos continentes, oceano, entre outras. Estas informa\u00e7\u00f5es s\u00e3o bastante utilizadas em qualquer mapa como base, mas dependendo do caso, ter a camada completa n\u00e3o \u00e9 interessante. Por isso, vamos ensinar como voc\u00ea pode baixar&#8230; <a class=\"more-link\" href=\"https:\/\/www.fernandoquadro.com.br\/html\/2016\/05\/03\/como-criar-sua-camada-a-partir-do-openstreetmap\/\">Continue Reading &rarr;<\/a><\/p>\n","protected":false},"author":275,"featured_media":5156,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[24,11],"tags":[223,166,212],"class_list":["post-5154","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-gis","category-postgis","tag-gis","tag-openstreetmap","tag-postgis"],"_links":{"self":[{"href":"https:\/\/www.fernandoquadro.com.br\/html\/wp-json\/wp\/v2\/posts\/5154","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=5154"}],"version-history":[{"count":5,"href":"https:\/\/www.fernandoquadro.com.br\/html\/wp-json\/wp\/v2\/posts\/5154\/revisions"}],"predecessor-version":[{"id":8348,"href":"https:\/\/www.fernandoquadro.com.br\/html\/wp-json\/wp\/v2\/posts\/5154\/revisions\/8348"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/www.fernandoquadro.com.br\/html\/wp-json\/wp\/v2\/media\/5156"}],"wp:attachment":[{"href":"https:\/\/www.fernandoquadro.com.br\/html\/wp-json\/wp\/v2\/media?parent=5154"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.fernandoquadro.com.br\/html\/wp-json\/wp\/v2\/categories?post=5154"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.fernandoquadro.com.br\/html\/wp-json\/wp\/v2\/tags?post=5154"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}