From 743162c76e9d1d9aadb0e406c2d7f272ea3a646c Mon Sep 17 00:00:00 2001 From: nebulon42 Date: Mon, 29 Aug 2016 22:58:41 +0200 Subject: [PATCH 1/5] mark places with a dot on low zooms, changes in capital cities rendering, do not let state labels obscure captial city names (fixes #1883) --- placenames.mss | 170 +++++++++++++++++++++--------- project.mml | 62 ++++++++++- project.yaml | 70 +++++++++--- symbols/place/place-4.svg | 37 +++++++ symbols/place/place-6.svg | 36 +++++++ symbols/place/place-capital-6.svg | 40 +++++++ symbols/place/place-capital-8.svg | 40 +++++++ 7 files changed, 387 insertions(+), 68 deletions(-) create mode 100644 symbols/place/place-4.svg create mode 100644 symbols/place/place-6.svg create mode 100644 symbols/place/place-capital-6.svg create mode 100644 symbols/place/place-capital-8.svg diff --git a/placenames.mss b/placenames.mss index e5e33db17e..5a7d913fdb 100644 --- a/placenames.mss +++ b/placenames.mss @@ -4,7 +4,7 @@ @state-labels: desaturate(darken(@admin-boundaries, 5%), 20%); .country { - [admin_level = '2'][zoom >= 3][way_pixels > 1000][way_pixels < 360000] { + [zoom >= 3][way_pixels > 1000][way_pixels < 360000] { text-name: "[name]"; text-size: 10; [zoom >= 4] { @@ -31,56 +31,111 @@ } .state { - [admin_level = '4'] { - [zoom >= 4][zoom < 5][way_pixels > 750], - [zoom >= 5][way_pixels > 3000][way_pixels < 196000] { - text-name: "[ref]"; - text-size: 9; - text-fill: @state-labels; - text-face-name: @oblique-fonts; - text-halo-fill: @standard-halo-fill; - text-halo-radius: @standard-halo-radius * 1.5; - text-wrap-width: 0; - text-placement: interior; - [zoom >= 5] { - text-name: "[name]"; - text-wrap-width: 30; - } - [zoom >= 7] { - text-size: 11; - text-wrap-width: 50; - } + [zoom >= 4][zoom < 5][way_pixels > 750], + [zoom >= 5][way_pixels > 3000][way_pixels < 196000] { + text-name: "[ref]"; + text-size: 9; + text-fill: @state-labels; + text-face-name: @oblique-fonts; + text-halo-fill: @standard-halo-fill; + text-halo-radius: @standard-halo-radius * 1.5; + text-wrap-width: 0; + text-placement: interior; + [zoom >= 5] { + text-name: "[name]"; + text-wrap-width: 30; + } + [zoom >= 7] { + text-size: 11; + text-wrap-width: 50; + } + } +} + +#capital-names { + [zoom >= 4][zoom < 8][population > 600000], + [zoom >= 5][zoom < 8] { + shield-file: url('symbols/place/place-capital-6.svg'); + shield-text-dy: 6; + shield-name: '[name]'; + shield-face-name: @book-fonts; + shield-fill: @placenames; + shield-size: 11; + shield-min-distance: 10; + shield-wrap-width: 30; + shield-halo-fill: @standard-halo-fill; + shield-halo-radius: @standard-halo-radius * 1.5; + shield-placement-type: simple; + shield-placements: 'S,N'; + shield-unlock-image: true; + + [zoom >= 5] { + shield-wrap-width: 45; + } + [zoom >= 6] { + shield-size: 12; + shield-wrap-width: 60; + } + [zoom >= 7] { + shield-file: url('symbols/place/place-capital-8.svg'); + shield-text-dy: 7; + } + } + [zoom >= 8] { + text-name: '[name]'; + text-face-name: @book-fonts; + text-fill: @placenames; + text-size: 13; + text-min-distance: 10; + text-wrap-width: 60; + text-halo-fill: @standard-halo-fill; + text-halo-radius: @standard-halo-radius * 1.5; + + [zoom >= 11] { + text-size: 15; + text-wrap-width: 75; } } } #placenames-medium::high-importance { - [category = 1][zoom < 14] { - [zoom >= 4][score >= 3000000], - [zoom >= 5][score >= 400000] { - text-name: "[name]"; - text-size: 11; - text-fill: @placenames; - text-face-name: @book-fonts; - text-halo-radius: @standard-halo-radius * 1.5; - text-halo-fill: @standard-halo-fill; - text-wrap-width: 30; + [category = 1][zoom < 14][score >= 400000] { + [zoom >= 5][zoom < 8] { + shield-file: url('symbols/place/place-4.svg'); + shield-text-dy: 4; + shield-name: '[name]'; + shield-face-name: @book-fonts; + shield-fill: @placenames; + shield-size: 11; + shield-min-distance: 10; + shield-wrap-width: 30; + shield-halo-fill: @standard-halo-fill; + shield-halo-radius: @standard-halo-radius * 1.5; + shield-placement-type: simple; + shield-placements: 'S,N'; + shield-unlock-image: true; + [zoom >= 5] { - text-size: 11; - text-wrap-width: 45; + shield-wrap-width: 45; } [zoom >= 6] { - text-size: 12; - text-wrap-width: 60; - } - [zoom >= 8] { - text-size: 13; - text-wrap-width: 60; - } - [zoom >= 9] { - text-size: 14; - text-wrap-width: 65; + shield-size: 12; + shield-wrap-width: 60; + + shield-file: url('symbols/place/place-6.svg'); + shield-text-dy: 5; } + } + [zoom >= 8] { + text-name: '[name]'; + text-face-name: @book-fonts; + text-fill: @placenames; + text-size: 13; + text-min-distance: 10; + text-wrap-width: 60; + text-halo-fill: @standard-halo-fill; + text-halo-radius: @standard-halo-radius * 1.5; + [zoom >= 11] { text-size: 15; text-wrap-width: 75; @@ -91,15 +146,31 @@ #placenames-medium::medium-importance { [category = 1][score < 400000][zoom < 15] { - [zoom >= 6][score >= 70000], + [zoom >= 6][zoom < 8][score >= 70000], + [zoom >= 7][zoom < 8] { + shield-file: url('symbols/place/place-4.svg'); + shield-text-dy: 4; + shield-name: "[name]"; + shield-size: 10; + shield-fill: @placenames; + shield-face-name: @book-fonts; + shield-halo-fill: @standard-halo-fill; + shield-halo-radius: @standard-halo-radius * 1.5; + shield-wrap-width: 30; + shield-min-distance: 10; + shield-placement-type: simple; + shield-placements: 'S,N'; + shield-unlock-image: true; + } [zoom >= 7] { text-name: "[name]"; text-size: 10; text-fill: @placenames; text-face-name: @book-fonts; - text-halo-radius: @standard-halo-radius * 1.5; text-halo-fill: @standard-halo-fill; - text-wrap-width: 30; + text-halo-radius: @standard-halo-radius * 1.5; + text-wrap-width: 60; + text-min-distance: 10; [zoom >= 9] { text-size: 12; text-wrap-width: 60; @@ -123,8 +194,8 @@ text-size: 10; text-fill: @placenames; text-face-name: @book-fonts; - text-halo-radius: @standard-halo-radius * 1.5; text-halo-fill: @standard-halo-fill; + text-halo-radius: @standard-halo-radius * 1.5; text-wrap-width: 45; [zoom >= 11] { text-size: 11; @@ -148,8 +219,8 @@ text-size: 11; text-fill: @placenames; text-face-name: @book-fonts; - text-halo-radius: @standard-halo-radius * 1.5; text-halo-fill: @standard-halo-fill; + text-halo-radius: @standard-halo-radius * 1.5; text-wrap-width: 55; [zoom >= 14] { text-size: 14; @@ -171,8 +242,8 @@ text-size: 10; text-fill: @placenames; text-face-name: @book-fonts; - text-halo-radius: @standard-halo-radius * 1.5; text-halo-fill: @standard-halo-fill; + text-halo-radius: @standard-halo-radius * 1.5; text-wrap-width: 50; [zoom >= 14] { text-fill: @placenames-light; @@ -199,8 +270,8 @@ text-size: 10; text-fill: @placenames; text-face-name: @book-fonts; - text-halo-radius: @standard-halo-radius * 1.5; text-halo-fill: @standard-halo-fill; + text-halo-radius: @standard-halo-radius * 1.5; text-wrap-width: 45; } [zoom >= 16] { @@ -211,3 +282,4 @@ } } } + diff --git a/project.mml b/project.mml index f164e78847..52f7b9a5f0 100644 --- a/project.mml +++ b/project.mml @@ -1258,15 +1258,15 @@ "advanced": {} }, { - "name": "placenames-large", + "name": "country-names", "srs-name": "900913", "geometry": "point", - "class": "country state", - "id": "placenames-large", + "class": "country", + "id": "country-names", "srs": "+proj=merc +a=6378137 +b=6378137 +lat_ts=0.0 +lon_0=0.0 +x_0=0.0 +y_0=0.0 +k=1.0 +units=m +nadgrids=@null +wktext +no_defs +over", "Datasource": { "extent": "-20037508,-20037508,20037508,20037508", - "table": "(SELECT\n way,\n way_area/NULLIF(!pixel_width!::real*!pixel_height!::real,0) AS way_pixels,\n name,\n ref,\n admin_level\n FROM planet_osm_polygon\n WHERE boundary = 'administrative'\n AND admin_level IN ('2', '4')\n AND name IS NOT NULL\n AND way_area > 750*!pixel_width!::real*!pixel_height!::real -- only labels for larger areas are displayed\n ORDER BY admin_level ASC, way_area DESC\n) AS placenames_large", + "table": "(SELECT\n way,\n way_area/NULLIF(!pixel_width!::real*!pixel_height!::real,0) AS way_pixels,\n name\n FROM planet_osm_polygon\n WHERE boundary = 'administrative'\n AND admin_level = '2'\n AND name IS NOT NULL\n AND way_area > 100*!pixel_width!::real*!pixel_height!::real\n ORDER BY way_area DESC\n) AS country_names", "geometry_field": "way", "type": "postgis", "key_field": "", @@ -1280,6 +1280,58 @@ ], "properties": { "minzoom": 2 + } + }, + { + "name": "capital-names", + "srs-name": "900913", + "geometry": "point", + "class": "", + "id": "capital-names", + "srs": "+proj=merc +a=6378137 +b=6378137 +lat_ts=0.0 +lon_0=0.0 +x_0=0.0 +y_0=0.0 +k=1.0 +units=m +nadgrids=@null +wktext +no_defs +over", + "Datasource": { + "extent": "-20037508,-20037508,20037508,20037508", + "table": "(SELECT\n way,\n name,\n CASE\n WHEN population ~ '^-?\\d+(\\.\\d+)?$' THEN population::NUMERIC ELSE 0\n END as population\n FROM planet_osm_point\n WHERE capital = 'yes'\n AND (admin_level = '2' OR admin_level IS NULL)\n ORDER BY population DESC\n) AS capital_names", + "geometry_field": "way", + "type": "postgis", + "key_field": "", + "dbname": "gis" + }, + "extent": [ + -180, + -85.05112877980659, + 180, + 85.05112877980659 + ], + "properties": { + "maxzoom": 15, + "minzoom": 3 + }, + "advanced": {} + }, + { + "name": "state-names", + "srs-name": "900913", + "geometry": "point", + "class": "state", + "id": "state-names", + "srs": "+proj=merc +a=6378137 +b=6378137 +lat_ts=0.0 +lon_0=0.0 +x_0=0.0 +y_0=0.0 +k=1.0 +units=m +nadgrids=@null +wktext +no_defs +over", + "Datasource": { + "extent": "-20037508,-20037508,20037508,20037508", + "table": "(SELECT\n way,\n way_area/NULLIF(!pixel_width!::real*!pixel_height!::real,0) AS way_pixels,\n name,\n ref\n FROM planet_osm_polygon\n WHERE boundary = 'administrative'\n AND admin_level = '4'\n AND name IS NOT NULL\n AND way_area > 100*!pixel_width!::real*!pixel_height!::real\n ORDER BY way_area DESC\n) AS state_names", + "geometry_field": "way", + "type": "postgis", + "key_field": "", + "dbname": "gis" + }, + "extent": [ + -180, + -85.05112877980659, + 180, + 85.05112877980659 + ], + "properties": { + "minzoom": 4 }, "advanced": {} }, @@ -1292,7 +1344,7 @@ "srs": "+proj=merc +a=6378137 +b=6378137 +lat_ts=0.0 +lon_0=0.0 +x_0=0.0 +y_0=0.0 +k=1.0 +units=m +nadgrids=@null +wktext +no_defs +over", "Datasource": { "extent": "-20037508,-20037508,20037508,20037508", - "table": "(SELECT\n way,\n name,\n score,\n CASE\n WHEN (place = 'city' OR (capital = 'yes' AND score >= 100000)) THEN 1\n ELSE 2\n END as category\n FROM \n (SELECT\n way,\n place,\n name,\n capital,\n (\n (CASE\n WHEN (population ~ '^[0-9]{1,8}$') THEN population::INTEGER\n WHEN (place = 'city') THEN 100000\n WHEN (place = 'town') THEN 1000\n ELSE 1\n END)\n *\n (CASE\n WHEN (capital = 'yes') THEN 3\n WHEN (capital = '4') THEN 2\n ELSE 1\n END)\n ) AS score\n FROM planet_osm_point\n WHERE place IN ('city', 'town')\n AND name IS NOT NULL\n ) as p\n ORDER BY score DESC, length(name) DESC, name\n) AS placenames_medium", + "table": "(SELECT\n way,\n name,\n score,\n CASE\n WHEN (place = 'city') THEN 1\n ELSE 2\n END as category\n FROM \n (SELECT\n way,\n place,\n name,\n (\n (CASE\n WHEN (population ~ '^[0-9]{1,8}$') THEN population::INTEGER\n WHEN (place = 'city') THEN 100000\n WHEN (place = 'town') THEN 1000\n ELSE 1\n END)\n *\n (CASE\n WHEN (capital = '4' OR (capital = 'yes' AND admin_level = '4')) THEN 2\n ELSE 1\n END)\n ) AS score\n FROM planet_osm_point\n WHERE place IN ('city', 'town')\n AND name IS NOT NULL\n AND capital IS NULL OR capital = '4' OR (capital = 'yes' AND admin_level = '4')\n ) as p\n ORDER BY score DESC, length(name) DESC, name\n) AS placenames_medium", "geometry_field": "way", "type": "postgis", "key_field": "", diff --git a/project.yaml b/project.yaml index 98b4b782ed..144d24e02c 100644 --- a/project.yaml +++ b/project.yaml @@ -1490,9 +1490,9 @@ Layer: properties: minzoom: 16 advanced: {} - - id: "placenames-large" - name: "placenames-large" - class: "country state" + - id: "country-names" + name: "country-names" + class: "country" geometry: "point" <<: *extents Datasource: @@ -1501,18 +1501,61 @@ Layer: (SELECT way, way_area/NULLIF(!pixel_width!::real*!pixel_height!::real,0) AS way_pixels, - name, - ref, - admin_level + name FROM planet_osm_polygon WHERE boundary = 'administrative' - AND admin_level IN ('2', '4') + AND admin_level = '2' AND name IS NOT NULL - AND way_area > 750*!pixel_width!::real*!pixel_height!::real -- only labels for larger areas are displayed - ORDER BY admin_level ASC, way_area DESC - ) AS placenames_large + AND way_area > 100*!pixel_width!::real*!pixel_height!::real + ORDER BY way_area DESC + ) AS country_names properties: minzoom: 2 + - id: "capital-names" + name: "capital-names" + class: "" + geometry: "point" + <<: *extents + Datasource: + <<: *osm2pgsql + table: |- + (SELECT + way, + name, + CASE + WHEN population ~ '^-?\d+(\.\d+)?$' THEN population::NUMERIC ELSE 0 + END as population + FROM planet_osm_point + WHERE capital = 'yes' + AND (admin_level = '2' OR admin_level IS NULL) + ORDER BY population DESC + ) AS capital_names + properties: + minzoom: 3 + maxzoom: 15 + advanced: {} + - id: "state-names" + name: "state-names" + class: "state" + geometry: "point" + <<: *extents + Datasource: + <<: *osm2pgsql + table: |- + (SELECT + way, + way_area/NULLIF(!pixel_width!::real*!pixel_height!::real,0) AS way_pixels, + name, + ref + FROM planet_osm_polygon + WHERE boundary = 'administrative' + AND admin_level = '4' + AND name IS NOT NULL + AND way_area > 100*!pixel_width!::real*!pixel_height!::real + ORDER BY way_area DESC + ) AS state_names + properties: + minzoom: 4 advanced: {} - id: "placenames-medium" name: "placenames-medium" @@ -1527,7 +1570,7 @@ Layer: name, score, CASE - WHEN (place = 'city' OR (capital = 'yes' AND score >= 100000)) THEN 1 + WHEN (place = 'city') THEN 1 ELSE 2 END as category FROM @@ -1535,7 +1578,6 @@ Layer: way, place, name, - capital, ( (CASE WHEN (population ~ '^[0-9]{1,8}$') THEN population::INTEGER @@ -1545,14 +1587,14 @@ Layer: END) * (CASE - WHEN (capital = 'yes') THEN 3 - WHEN (capital = '4') THEN 2 + WHEN (capital = '4' OR (capital = 'yes' AND admin_level = '4')) THEN 2 ELSE 1 END) ) AS score FROM planet_osm_point WHERE place IN ('city', 'town') AND name IS NOT NULL + AND capital IS NULL OR capital = '4' OR (capital = 'yes' AND admin_level = '4') ) as p ORDER BY score DESC, length(name) DESC, name ) AS placenames_medium diff --git a/symbols/place/place-4.svg b/symbols/place/place-4.svg new file mode 100644 index 0000000000..1190e04edc --- /dev/null +++ b/symbols/place/place-4.svg @@ -0,0 +1,37 @@ + + + + + + + + + image/svg+xml + + + + + + + + + diff --git a/symbols/place/place-6.svg b/symbols/place/place-6.svg new file mode 100644 index 0000000000..c1d6dca450 --- /dev/null +++ b/symbols/place/place-6.svg @@ -0,0 +1,36 @@ + + + + + + + + + image/svg+xml + + + + + + + + + diff --git a/symbols/place/place-capital-6.svg b/symbols/place/place-capital-6.svg new file mode 100644 index 0000000000..017c316869 --- /dev/null +++ b/symbols/place/place-capital-6.svg @@ -0,0 +1,40 @@ + + + + + + + + + image/svg+xml + + + + + + + + + + diff --git a/symbols/place/place-capital-8.svg b/symbols/place/place-capital-8.svg new file mode 100644 index 0000000000..b265397261 --- /dev/null +++ b/symbols/place/place-capital-8.svg @@ -0,0 +1,40 @@ + + + + + + + + + image/svg+xml + + + + + + + + + + From 3747894f3d680f555448b74876c6092611c19904 Mon Sep 17 00:00:00 2001 From: nebulon42 Date: Tue, 30 Aug 2016 21:39:56 +0200 Subject: [PATCH 2/5] bigger text size, no capitals at z3, fewer capitals on z4, be more strict with capitals, no dots at z8, N,S,E,W placement, correction of query --- placenames.mss | 17 +++++++++++------ project.mml | 4 ++-- project.yaml | 6 +++--- 3 files changed, 16 insertions(+), 11 deletions(-) diff --git a/placenames.mss b/placenames.mss index 5a7d913fdb..27ae09cb0f 100644 --- a/placenames.mss +++ b/placenames.mss @@ -56,17 +56,18 @@ [zoom >= 4][zoom < 8][population > 600000], [zoom >= 5][zoom < 8] { shield-file: url('symbols/place/place-capital-6.svg'); + shield-text-dx: 6; shield-text-dy: 6; shield-name: '[name]'; shield-face-name: @book-fonts; shield-fill: @placenames; shield-size: 11; - shield-min-distance: 10; + shield-min-distance: 5; shield-wrap-width: 30; shield-halo-fill: @standard-halo-fill; shield-halo-radius: @standard-halo-radius * 1.5; shield-placement-type: simple; - shield-placements: 'S,N'; + shield-placements: 'S,N,E,W'; shield-unlock-image: true; [zoom >= 5] { @@ -78,6 +79,7 @@ } [zoom >= 7] { shield-file: url('symbols/place/place-capital-8.svg'); + shield-text-dx: 7; shield-text-dy: 7; } } @@ -102,17 +104,18 @@ [category = 1][zoom < 14][score >= 400000] { [zoom >= 5][zoom < 8] { shield-file: url('symbols/place/place-4.svg'); + shield-text-dx: 4; shield-text-dy: 4; shield-name: '[name]'; shield-face-name: @book-fonts; shield-fill: @placenames; shield-size: 11; - shield-min-distance: 10; + shield-min-distance: 5; shield-wrap-width: 30; shield-halo-fill: @standard-halo-fill; shield-halo-radius: @standard-halo-radius * 1.5; shield-placement-type: simple; - shield-placements: 'S,N'; + shield-placements: 'S,N,E,W'; shield-unlock-image: true; [zoom >= 5] { @@ -123,6 +126,7 @@ shield-wrap-width: 60; shield-file: url('symbols/place/place-6.svg'); + shield-text-dx: 5; shield-text-dy: 5; } } @@ -149,6 +153,7 @@ [zoom >= 6][zoom < 8][score >= 70000], [zoom >= 7][zoom < 8] { shield-file: url('symbols/place/place-4.svg'); + shield-text-dx: 4; shield-text-dy: 4; shield-name: "[name]"; shield-size: 10; @@ -157,9 +162,9 @@ shield-halo-fill: @standard-halo-fill; shield-halo-radius: @standard-halo-radius * 1.5; shield-wrap-width: 30; - shield-min-distance: 10; + shield-min-distance: 5; shield-placement-type: simple; - shield-placements: 'S,N'; + shield-placements: 'S,N,E,W'; shield-unlock-image: true; } [zoom >= 7] { diff --git a/project.mml b/project.mml index 52f7b9a5f0..63032d538f 100644 --- a/project.mml +++ b/project.mml @@ -1291,7 +1291,7 @@ "srs": "+proj=merc +a=6378137 +b=6378137 +lat_ts=0.0 +lon_0=0.0 +x_0=0.0 +y_0=0.0 +k=1.0 +units=m +nadgrids=@null +wktext +no_defs +over", "Datasource": { "extent": "-20037508,-20037508,20037508,20037508", - "table": "(SELECT\n way,\n name,\n CASE\n WHEN population ~ '^-?\\d+(\\.\\d+)?$' THEN population::NUMERIC ELSE 0\n END as population\n FROM planet_osm_point\n WHERE capital = 'yes'\n AND (admin_level = '2' OR admin_level IS NULL)\n ORDER BY population DESC\n) AS capital_names", + "table": "(SELECT\n way,\n name,\n CASE\n WHEN (population ~ '^[0-9]{1,8}$') THEN population::INTEGER ELSE 0\n END as population\n FROM planet_osm_point\n WHERE capital = 'yes'\n AND admin_level = '2'\n ORDER BY population DESC\n) AS capital_names", "geometry_field": "way", "type": "postgis", "key_field": "", @@ -1344,7 +1344,7 @@ "srs": "+proj=merc +a=6378137 +b=6378137 +lat_ts=0.0 +lon_0=0.0 +x_0=0.0 +y_0=0.0 +k=1.0 +units=m +nadgrids=@null +wktext +no_defs +over", "Datasource": { "extent": "-20037508,-20037508,20037508,20037508", - "table": "(SELECT\n way,\n name,\n score,\n CASE\n WHEN (place = 'city') THEN 1\n ELSE 2\n END as category\n FROM \n (SELECT\n way,\n place,\n name,\n (\n (CASE\n WHEN (population ~ '^[0-9]{1,8}$') THEN population::INTEGER\n WHEN (place = 'city') THEN 100000\n WHEN (place = 'town') THEN 1000\n ELSE 1\n END)\n *\n (CASE\n WHEN (capital = '4' OR (capital = 'yes' AND admin_level = '4')) THEN 2\n ELSE 1\n END)\n ) AS score\n FROM planet_osm_point\n WHERE place IN ('city', 'town')\n AND name IS NOT NULL\n AND capital IS NULL OR capital = '4' OR (capital = 'yes' AND admin_level = '4')\n ) as p\n ORDER BY score DESC, length(name) DESC, name\n) AS placenames_medium", + "table": "(SELECT\n way,\n name,\n score,\n CASE\n WHEN (place = 'city') THEN 1\n ELSE 2\n END as category\n FROM \n (SELECT\n way,\n place,\n name,\n (\n (CASE\n WHEN (population ~ '^[0-9]{1,8}$') THEN population::INTEGER\n WHEN (place = 'city') THEN 100000\n WHEN (place = 'town') THEN 1000\n ELSE 1\n END)\n *\n (CASE\n WHEN (capital = '4' OR (capital = 'yes' AND admin_level = '4')) THEN 2\n ELSE 1\n END)\n ) AS score\n FROM planet_osm_point\n WHERE place IN ('city', 'town')\n AND name IS NOT NULL\n AND capital IS NULL OR capital != '2' OR (capital = 'yes' AND admin_level != '2')\n ) as p\n ORDER BY score DESC, length(name) DESC, name\n) AS placenames_medium", "geometry_field": "way", "type": "postgis", "key_field": "", diff --git a/project.yaml b/project.yaml index 144d24e02c..8051d272f1 100644 --- a/project.yaml +++ b/project.yaml @@ -1523,11 +1523,11 @@ Layer: way, name, CASE - WHEN population ~ '^-?\d+(\.\d+)?$' THEN population::NUMERIC ELSE 0 + WHEN (population ~ '^[0-9]{1,8}$') THEN population::INTEGER ELSE 0 END as population FROM planet_osm_point WHERE capital = 'yes' - AND (admin_level = '2' OR admin_level IS NULL) + AND admin_level = '2' ORDER BY population DESC ) AS capital_names properties: @@ -1594,7 +1594,7 @@ Layer: FROM planet_osm_point WHERE place IN ('city', 'town') AND name IS NOT NULL - AND capital IS NULL OR capital = '4' OR (capital = 'yes' AND admin_level = '4') + AND capital IS NULL OR capital != '2' OR (capital = 'yes' AND admin_level != '2') ) as p ORDER BY score DESC, length(name) DESC, name ) AS placenames_medium From 5da5e67427d1a3bba97d50c1999a9c446b0d6895 Mon Sep 17 00:00:00 2001 From: nebulon42 Date: Fri, 2 Sep 2016 20:56:33 +0200 Subject: [PATCH 3/5] stronger dots on higher zooms, more place names on z4, optimized spacing between labels --- placenames.mss | 31 ++++++++++++++++++++++++------- project.mml | 4 ++-- project.yaml | 6 ++++-- symbols/place/place-4-z7.svg | 30 ++++++++++++++++++++++++++++++ symbols/place/place-4.svg | 15 ++++----------- symbols/place/place-6-z7.svg | 30 ++++++++++++++++++++++++++++++ symbols/place/place-6.svg | 14 ++++---------- symbols/place/place-capital-6.svg | 16 +++++----------- symbols/place/place-capital-8.svg | 8 +++----- 9 files changed, 106 insertions(+), 48 deletions(-) create mode 100644 symbols/place/place-4-z7.svg create mode 100644 symbols/place/place-6-z7.svg diff --git a/placenames.mss b/placenames.mss index 27ae09cb0f..f243b3e3cf 100644 --- a/placenames.mss +++ b/placenames.mss @@ -68,6 +68,9 @@ shield-halo-radius: @standard-halo-radius * 1.5; shield-placement-type: simple; shield-placements: 'S,N,E,W'; + [dir = 1] { + shield-placements: 'N,S,E,W'; + } shield-unlock-image: true; [zoom >= 5] { @@ -88,7 +91,7 @@ text-face-name: @book-fonts; text-fill: @placenames; text-size: 13; - text-min-distance: 10; + text-margin: 6; text-wrap-width: 60; text-halo-fill: @standard-halo-fill; text-halo-radius: @standard-halo-radius * 1.5; @@ -101,8 +104,9 @@ } #placenames-medium::high-importance { - [category = 1][zoom < 14][score >= 400000] { - [zoom >= 5][zoom < 8] { + [category = 1][zoom < 14] { + [zoom >= 4][zoom < 5][score >= 3000000], + [zoom >= 5][zoom < 8][score >= 400000] { shield-file: url('symbols/place/place-4.svg'); shield-text-dx: 4; shield-text-dy: 4; @@ -116,6 +120,9 @@ shield-halo-radius: @standard-halo-radius * 1.5; shield-placement-type: simple; shield-placements: 'S,N,E,W'; + [dir = 1] { + shield-placements: 'N,S,E,W'; + } shield-unlock-image: true; [zoom >= 5] { @@ -129,13 +136,16 @@ shield-text-dx: 5; shield-text-dy: 5; } + [zoom >= 7] { + shield-file: url('symbols/place/place-6-z7.svg'); + } } - [zoom >= 8] { + [zoom >= 8][score >= 400000] { text-name: '[name]'; text-face-name: @book-fonts; text-fill: @placenames; text-size: 13; - text-min-distance: 10; + text-margin: 6; text-wrap-width: 60; text-halo-fill: @standard-halo-fill; text-halo-radius: @standard-halo-radius * 1.5; @@ -165,9 +175,15 @@ shield-min-distance: 5; shield-placement-type: simple; shield-placements: 'S,N,E,W'; + [dir = 1] { + shield-placements: 'N,S,E,W'; + } shield-unlock-image: true; + [zoom >= 7] { + shield-file: url('symbols/place/place-4-z7.svg'); + } } - [zoom >= 7] { + [zoom >= 8] { text-name: "[name]"; text-size: 10; text-fill: @placenames; @@ -175,7 +191,7 @@ text-halo-fill: @standard-halo-fill; text-halo-radius: @standard-halo-radius * 1.5; text-wrap-width: 60; - text-min-distance: 10; + text-margin: 6; [zoom >= 9] { text-size: 12; text-wrap-width: 60; @@ -202,6 +218,7 @@ text-halo-fill: @standard-halo-fill; text-halo-radius: @standard-halo-radius * 1.5; text-wrap-width: 45; + text-margin: 6; [zoom >= 11] { text-size: 11; text-wrap-width: 55; diff --git a/project.mml b/project.mml index 63032d538f..46279cffe3 100644 --- a/project.mml +++ b/project.mml @@ -1291,7 +1291,7 @@ "srs": "+proj=merc +a=6378137 +b=6378137 +lat_ts=0.0 +lon_0=0.0 +x_0=0.0 +y_0=0.0 +k=1.0 +units=m +nadgrids=@null +wktext +no_defs +over", "Datasource": { "extent": "-20037508,-20037508,20037508,20037508", - "table": "(SELECT\n way,\n name,\n CASE\n WHEN (population ~ '^[0-9]{1,8}$') THEN population::INTEGER ELSE 0\n END as population\n FROM planet_osm_point\n WHERE capital = 'yes'\n AND admin_level = '2'\n ORDER BY population DESC\n) AS capital_names", + "table": "(SELECT\n way,\n name,\n CASE\n WHEN (population ~ '^[0-9]{1,8}$') THEN population::INTEGER ELSE 0\n END as population,\n round(random()) AS dir\n FROM planet_osm_point\n WHERE capital = 'yes'\n AND admin_level = '2'\n ORDER BY population DESC\n) AS capital_names", "geometry_field": "way", "type": "postgis", "key_field": "", @@ -1344,7 +1344,7 @@ "srs": "+proj=merc +a=6378137 +b=6378137 +lat_ts=0.0 +lon_0=0.0 +x_0=0.0 +y_0=0.0 +k=1.0 +units=m +nadgrids=@null +wktext +no_defs +over", "Datasource": { "extent": "-20037508,-20037508,20037508,20037508", - "table": "(SELECT\n way,\n name,\n score,\n CASE\n WHEN (place = 'city') THEN 1\n ELSE 2\n END as category\n FROM \n (SELECT\n way,\n place,\n name,\n (\n (CASE\n WHEN (population ~ '^[0-9]{1,8}$') THEN population::INTEGER\n WHEN (place = 'city') THEN 100000\n WHEN (place = 'town') THEN 1000\n ELSE 1\n END)\n *\n (CASE\n WHEN (capital = '4' OR (capital = 'yes' AND admin_level = '4')) THEN 2\n ELSE 1\n END)\n ) AS score\n FROM planet_osm_point\n WHERE place IN ('city', 'town')\n AND name IS NOT NULL\n AND capital IS NULL OR capital != '2' OR (capital = 'yes' AND admin_level != '2')\n ) as p\n ORDER BY score DESC, length(name) DESC, name\n) AS placenames_medium", + "table": "(SELECT\n way,\n name,\n score,\n CASE\n WHEN (place = 'city') THEN 1\n ELSE 2\n END as category,\n round(random()) AS dir\n FROM \n (SELECT\n way,\n place,\n name,\n (\n (CASE\n WHEN (population ~ '^[0-9]{1,8}$') THEN population::INTEGER\n WHEN (place = 'city') THEN 100000\n WHEN (place = 'town') THEN 1000\n ELSE 1\n END)\n *\n (CASE\n WHEN (capital = '4' OR (capital = 'yes' AND admin_level = '4')) THEN 2\n ELSE 1\n END)\n ) AS score\n FROM planet_osm_point\n WHERE place IN ('city', 'town')\n AND name IS NOT NULL\n AND capital IS NULL OR capital != '2' OR (capital = 'yes' AND admin_level != '2')\n ) as p\n ORDER BY score DESC, length(name) DESC, name\n) AS placenames_medium", "geometry_field": "way", "type": "postgis", "key_field": "", diff --git a/project.yaml b/project.yaml index 8051d272f1..ca28ecdc3d 100644 --- a/project.yaml +++ b/project.yaml @@ -1524,7 +1524,8 @@ Layer: name, CASE WHEN (population ~ '^[0-9]{1,8}$') THEN population::INTEGER ELSE 0 - END as population + END as population, + round(random()) AS dir FROM planet_osm_point WHERE capital = 'yes' AND admin_level = '2' @@ -1572,7 +1573,8 @@ Layer: CASE WHEN (place = 'city') THEN 1 ELSE 2 - END as category + END as category, + round(random()) AS dir FROM (SELECT way, diff --git a/symbols/place/place-4-z7.svg b/symbols/place/place-4-z7.svg new file mode 100644 index 0000000000..4130e8d12a --- /dev/null +++ b/symbols/place/place-4-z7.svg @@ -0,0 +1,30 @@ + + + + + + + image/svg+xml + + + + + + + diff --git a/symbols/place/place-4.svg b/symbols/place/place-4.svg index 1190e04edc..11504018fa 100644 --- a/symbols/place/place-4.svg +++ b/symbols/place/place-4.svg @@ -1,6 +1,4 @@ - - - - - + diff --git a/symbols/place/place-6-z7.svg b/symbols/place/place-6-z7.svg new file mode 100644 index 0000000000..c4fe4efeb3 --- /dev/null +++ b/symbols/place/place-6-z7.svg @@ -0,0 +1,30 @@ + + + + + + + image/svg+xml + + + + + + + diff --git a/symbols/place/place-6.svg b/symbols/place/place-6.svg index c1d6dca450..e0abe6da97 100644 --- a/symbols/place/place-6.svg +++ b/symbols/place/place-6.svg @@ -1,6 +1,4 @@ - - - - - + diff --git a/symbols/place/place-capital-6.svg b/symbols/place/place-capital-6.svg index 017c316869..645aeb5b37 100644 --- a/symbols/place/place-capital-6.svg +++ b/symbols/place/place-capital-6.svg @@ -1,6 +1,4 @@ - - - - - + + style="fill:#575749;fill-opacity:1;stroke:none" /> diff --git a/symbols/place/place-capital-8.svg b/symbols/place/place-capital-8.svg index b265397261..e385e1a1cf 100644 --- a/symbols/place/place-capital-8.svg +++ b/symbols/place/place-capital-8.svg @@ -1,6 +1,4 @@ - - + style="fill:#fdfdfc;fill-opacity:1;stroke:#525244;stroke-width:0.79820418;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1" /> + style="fill:#525244;fill-opacity:1;stroke:none" /> From 0a45eb77080b5318e1109e00405b3e149804ab62 Mon Sep 17 00:00:00 2001 From: nebulon42 Date: Fri, 2 Sep 2016 21:15:40 +0200 Subject: [PATCH 4/5] let place shields avoid metatile boundaries --- placenames.mss | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/placenames.mss b/placenames.mss index f243b3e3cf..1decda5110 100644 --- a/placenames.mss +++ b/placenames.mss @@ -62,7 +62,8 @@ shield-face-name: @book-fonts; shield-fill: @placenames; shield-size: 11; - shield-min-distance: 5; + shield-margin: 5; + shield-avoid-edges: true; shield-wrap-width: 30; shield-halo-fill: @standard-halo-fill; shield-halo-radius: @standard-halo-radius * 1.5; @@ -114,7 +115,8 @@ shield-face-name: @book-fonts; shield-fill: @placenames; shield-size: 11; - shield-min-distance: 5; + shield-margin: 5; + shield-avoid-edges: true; shield-wrap-width: 30; shield-halo-fill: @standard-halo-fill; shield-halo-radius: @standard-halo-radius * 1.5; @@ -172,7 +174,8 @@ shield-halo-fill: @standard-halo-fill; shield-halo-radius: @standard-halo-radius * 1.5; shield-wrap-width: 30; - shield-min-distance: 5; + shield-margin: 5; + shield-avoid-edges: true; shield-placement-type: simple; shield-placements: 'S,N,E,W'; [dir = 1] { From 52d85dd14b23ece5a46729e0fbac3cbad61e1e22 Mon Sep 17 00:00:00 2001 From: nebulon42 Date: Sat, 3 Sep 2016 10:02:50 +0200 Subject: [PATCH 5/5] correct bug in SQL query --- project.mml | 2 +- project.yaml | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/project.mml b/project.mml index 46279cffe3..b0d35a5bd7 100644 --- a/project.mml +++ b/project.mml @@ -1344,7 +1344,7 @@ "srs": "+proj=merc +a=6378137 +b=6378137 +lat_ts=0.0 +lon_0=0.0 +x_0=0.0 +y_0=0.0 +k=1.0 +units=m +nadgrids=@null +wktext +no_defs +over", "Datasource": { "extent": "-20037508,-20037508,20037508,20037508", - "table": "(SELECT\n way,\n name,\n score,\n CASE\n WHEN (place = 'city') THEN 1\n ELSE 2\n END as category,\n round(random()) AS dir\n FROM \n (SELECT\n way,\n place,\n name,\n (\n (CASE\n WHEN (population ~ '^[0-9]{1,8}$') THEN population::INTEGER\n WHEN (place = 'city') THEN 100000\n WHEN (place = 'town') THEN 1000\n ELSE 1\n END)\n *\n (CASE\n WHEN (capital = '4' OR (capital = 'yes' AND admin_level = '4')) THEN 2\n ELSE 1\n END)\n ) AS score\n FROM planet_osm_point\n WHERE place IN ('city', 'town')\n AND name IS NOT NULL\n AND capital IS NULL OR capital != '2' OR (capital = 'yes' AND admin_level != '2')\n ) as p\n ORDER BY score DESC, length(name) DESC, name\n) AS placenames_medium", + "table": "(SELECT\n way,\n name,\n score,\n CASE\n WHEN (place = 'city') THEN 1\n ELSE 2\n END as category,\n round(random()) AS dir\n FROM \n (SELECT\n way,\n place,\n name,\n (\n (CASE\n WHEN (population ~ '^[0-9]{1,8}$') THEN population::INTEGER\n WHEN (place = 'city') THEN 100000\n WHEN (place = 'town') THEN 1000\n ELSE 1\n END)\n *\n (CASE\n WHEN (capital = '4' OR (capital = 'yes' AND admin_level = '4')) THEN 2\n ELSE 1\n END)\n ) AS score\n FROM planet_osm_point\n WHERE place IN ('city', 'town')\n AND name IS NOT NULL\n AND capital IS NULL OR capital != 'yes' OR (capital = 'yes' AND admin_level != '2')\n ) as p\n ORDER BY score DESC, length(name) DESC, name\n) AS placenames_medium", "geometry_field": "way", "type": "postgis", "key_field": "", diff --git a/project.yaml b/project.yaml index ca28ecdc3d..0b83940a30 100644 --- a/project.yaml +++ b/project.yaml @@ -1596,7 +1596,7 @@ Layer: FROM planet_osm_point WHERE place IN ('city', 'town') AND name IS NOT NULL - AND capital IS NULL OR capital != '2' OR (capital = 'yes' AND admin_level != '2') + AND capital IS NULL OR capital != 'yes' OR (capital = 'yes' AND admin_level != '2') ) as p ORDER BY score DESC, length(name) DESC, name ) AS placenames_medium