]> git.openstreetmap.org Git - potlatch2.git/blob - resources/potlatch.css
296f1ad975cc4c0e4bd328586af33148dbf2a03f
[potlatch2.git] / resources / potlatch.css
1 /*
2
3         Stylesheet that mimicks, to a certain extent, potlatch 1.x
4         Andy Allan, November 2009
5
6         Based heavily on:
7         MapCSS demonstration stylesheet
8         Richard Fairhurst, October 2009
9         
10 */
11
12 /* This rule applies to all areas (closed ways). Note that rules are applied in the order
13   they appear in the file, so later rules may replace this one for some ways.
14   This is used as a debugger for finding unstyled areas; it's obviously oversimplistic since
15   it picks up closed-loop highways. */
16
17 way :area { color: red; width: 1; fill-color: red; fill-opacity: 0.5; }
18
19 /* A set of fairly standard rules.
20   We use z-index to make sure high-priority roads appear above minor ones.
21   The default z-index is 5. If an object matches multiple rules with the same
22   z-index then the rules are "merged" (but individual properties become one or the other)  */
23
24 way[highway=motorway],way[highway=motorway_link],
25 way[highway=trunk],way[highway=trunk_link],
26 way[highway=primary],way[highway=primary_link],
27 way[highway=secondary],way[highway=secondary_link],
28 way[highway=tertiary],way[highway=tertiary_link],
29 way[highway=residential]                             { text: name; text-color: black; font-size: 7; text-position: line;}
30 way[highway=motorway],way[highway=motorway_link]    { z-index: 9; color: #809BC0; width: 7; casing-color: black; casing-width: 8; }
31 way[highway=trunk],way[highway=trunk_link]          { z-index: 9; color: #7FC97F; width: 7; casing-color: black; casing-width: 8; }
32 way[highway=primary],way[highway=primary_link]      { z-index: 8; color: #E46D71; width: 7; casing-color: black; casing-width: 8; }
33 way[highway=secondary],way[highway=secondary_link]  { z-index: 7; color: #FDBF6F; width: 7; casing-width: 8; }
34 way[highway=tertiary],way[highway=unclassified]     { z-index: 6; color: #FEFECB; width: 5; casing-width: 7; }
35 way[highway=residential]                            { z-index: 5; color: #E8E8E8; width: 5; casing-color: gray; casing-width: 7; }
36 way[highway=service]                                { color: white; width: 3; casing-width: 5; }
37
38 /* Pedestrian precincts need to be treated carefully. Only closed-loops with an explicit
39 area=yes tag should be filled. The below doesn't yet work as intended. */
40 way[highway=pedestrian] !:area { color: #ddddee; width: 5; casing-color: #555555; casing-width: 6; }
41 way[highway=pedestrian] :area  { color: #555555; width: 1; fill-color: #ddddee; fill-opacity: 0.8; }
42
43 way[highway=steps]     { color: #FF6644; width: 2; dashes: 4, 2; }
44 way[highway=footway]   { color: #FF6644; width: 2; dashes: 6, 3; }
45 way[highway=bridleway] { z-index:9; color: #996644; width: 2; dashes: 4, 2, 2, 2; }
46 way[highway=track]     { color: #996644; width: 2; dashes: 4, 2; }
47 way[highway=path]      { color: lightgreen; width: 2; dashes: 2, 2; }
48
49 way[waterway=river], way[waterway=canal] { color: blue; width: 2; text:name; text-color:blue; font-size:9; text-position: offset; text-offset: 7;}
50
51 way[barrier] {color: #000000; width: 1}
52
53 /* Fills can be solid colour or bitmap images */
54
55
56 way[natural] :area                          { color: #ADD6A5; width: 1; fill-color: #ADD6A5; fill-opacity: 0.2; }
57 way[landuse] :area                          { color: #444444; width: 2; fill-color: #444444; fill-opacity: 0.3; }
58 way[amenity],way[shop] :area                { color: #ADCEB5; width: 1; fill-color: #ADCEB5; fill-opacity: 0.2; }
59 way[leisure],way[sport] :area               { color: #8CD6B5; width: 1; fill-color: #8CD6B5; fill-opacity: 0.2; }
60 way[tourism] :area                          { color: #F7CECE; width: 1; fill-color: #F7CECE; fill-opacity: 0.2; }
61 way[historic],way[ruins] :area              { color: #F7F7DE; width: 1; fill-color: #F7F7DE; fill-opacity: 0.2; }
62 way[military] :area                         { color: #D6D6D6; width: 1; fill-color: #D6D6D6; fill-opacity: 0.2; }
63 way[building] :area                         { color: #ff6ec7; width: 1; fill-color: #ff6ec7; fill-opacity: 0.2; }
64 way[natural=water],
65 way[waterway] :area               { color: blue;    width: 2; fill-color: blue;    fill-opacity: 0.2; }
66 way[landuse=forest],way[natural=wood] :area { color: green;   width: 2; fill-color: green;   fill-opacity: 0.2; }
67 way[leisure=pitch],way[leisure=park]        { color: #44ff44; width: 1; fill-color: #44ff44; fill-opacity: 0.2; }
68 way[amenity=parking] :area                  { color: gray;    width: 1; fill-color: gray;    fill-opacity: 0.2; }
69 way[public_transport=pay_scale_area] :area  { color: gray;    width: 1; fill-color: gray;    fill-opacity: 0.1; }
70
71 /* Addressing. Nodes with addresses *and* match POIs should have a poi icon, so we put addressing first */ 
72
73 node[addr:housenumber],
74 node[addr:housename] { icon-image: circle; icon-width: 4; color: #B0E0E6; casing-color:blue; casing-width: 1; }
75 way[addr:interpolation] { color: #B0E0E6; width: 3; dashes: 3,3;}
76
77 /* POIs, too, can have bitmap icons - they can even be transparent */
78
79 node[amenity=pub] { icon-image: icons/pub.png; text-offset: 15; font-family: DejaVu; text: name; font-size: 9; }
80 node[place] { icon-image: icons/place.png; text-offset: 17; font-family: DejaVu; text: name; font-size: 9; font-weight: bold; text-decoration: underline; }
81 node[railway=station] { icon-image: icons/station.png; text-offset: 13; font-family: DejaVu; text: name; font-size: 9; font-weight: bold; }
82 node[aeroway=aerodrome] { icon-image: icons/airport.png; text-offset: 13; font-family: DejaVu; text: name; font-size: 10; }
83 node[amenity=atm] { icon-image: icons/atm.png; }
84 node[amenity=bank] { icon-image: icons/bank.png; text-offset: 15; text: name; }
85 node[highway=bus_stop] { icon-image: icons/bus_stop.png; }
86 node[amenity=cafe] { icon-image: icons/cafe.png; text-offset: 15; text: name; }
87 node[shop=convenience] { icon-image: icons/convenience.png; text-offset:15; text:name; }
88 node[shop=supermarket] { icon-image: icons/supermarket.png; text-offset:15; text:name; }
89 node[amenity=fast_food] { icon-image: icons/fast_food.png; text-offset:15; text: name; }
90 node[amenity=fire_station] { icon-image: icons/fire_station.png; }
91 node[amenity=hospital] { icon-image: icons/hospital.png; }
92 node[tourism=hotel] { icon-image: icons/hotel.png; }
93 node[amenity=parking] { icon-image: icons/parking.png; }
94 node[amenity=bicycle_parking] { icon-image: icons/parking_cycle.png; text-offset: 15; text: capacity; }
95 node[amenity=pharmacy] { icon-image: icons/pharmacy.png; }
96 node[amenity=pharmacy][dispensing=yes] { icon-image: icons/pharmacy_dispensing.png; }
97 node[amenity=police] { icon-image: icons/police.png; }
98 node[amenity=post_box] { icon-image: icons/post_box.png; }
99 node[amenity=recycling] { icon-image: icons/recycling.png; }
100 node[amenity=restaurant] { icon-image: icons/restaurant.png; }
101 node[amenity=school] { icon-image: icons/school.png; }
102 node[amenity=taxi] { icon-image: icons/taxi.png; }
103 node[amenity=telephone] { icon-image: icons/telephone.png; }
104 way node[barrier=gate], way node[highway=gate] { icon-image: icons/gate.png; }
105         
106 /* We can stack styles at different z-index (depth) */
107
108 way[railway=rail]
109         { z-index: 6; color: black; width: 5; } 
110         { z-index: 7; color: white; width: 3; dashes: 12,12; }
111 way[railway=subway]
112         { z-index: 6; color: #444444; width: 5; }
113         { z-index: 7; color: white; width: 3; dashes: 8,8; }
114
115 /* Bridge */
116 way[bridge=yes]
117     { z-index: 4; color: white; width: eval('_width+3'); }
118     { z-index: 3; color: black; width: eval('_width+6'); }
119     
120 /* Tunnel */
121 way[tunnel=yes]
122     { z-index: 4; color: white; width: eval('_width+2'); }
123     { z-index: 3; color: black; width: eval('_width+6'); dashes: 4,4; }
124
125 /* Change the road colour based on dynamically set "highlighted" tag (see earlier) */
126
127 way .highlighted { color: pink; }
128
129 /* Interactive editors may choose different behaviour when a user mouses-over or selects
130    an object. Potlatch 2 supports these but the stand-alone Halcyon viewer does not */
131
132 way :hover      { z-index: 2; width: eval('_width+10'); color: #ffff99; }
133 way :selected { z-index: 2; width: eval('_width+10'); color: yellow; opacity: 0.7;}
134 way !:drawn { z-index:10; width: 0.5; color: gray; } 
135
136 node :selectedway { z-index: 9; icon-image: square; icon-width: 8; color: red; }
137 node :hoverway { z-index: 9; icon-image: square; icon-width: 7; color: blue; }
138 node !:drawn :poi { z-index: 2; icon-image: circle; icon-width: 4; color: green; casing-color: black; casing-width: 1; }
139 node :selected { z-index: 1; icon-image: square; icon-width: eval('_width+10'); color: yellow; }
140 node :junction :selectedway { z-index: 8; icon-image: square; icon-width: 12; casing-color: black; casing-width: 1; }
141         
142 /* Descendant selectors provide an easy way to style relations: this example means "any way
143    which is part of a relation whose type=route". */
144
145 relation[type=route] way { z-index: 1; width: 17; color: blue; opacity: 0.3; }
146 relation[type=route][route=bicycle][network=ncn] way { z-index: 1; width: 12; color: red; opacity: 0.3; }
147 relation[type=route][route=bicycle][network=rcn] way { z-index: 1; width: 12; color: cyan; opacity: 0.3; }
148 relation[type=route][route=bicycle][network=lcn] way { z-index: 1; width: 12; color: blue; opacity: 0.3; }
149 relation[type=route][route=foot] way { z-index: 1; width: 10; color: #80ff80; opacity: 0.6; }
150
151