UCamGeoJSON: Difference between revisions
Line 233: | Line 233: | ||
| rect.png || [[File:Rect.png]] || a 40px open red square on a transparent background | | rect.png || [[File:Rect.png]] || a 40px open red square on a transparent background | ||
|- | |- | ||
| circle.png || [[File:Circle2.png]] || a 40px diameter solid red circle on a transparent background | | circle-r.png<br/>circle-b.png<br/>circle-g.png || [[File:Circle2.png]] || a 40px diameter solid red circle on a transparent background with -r suffix. Also in blue and green (-b and -g suffixes) | ||
|- | |- | ||
| block.png || [[File:Block.png]] || a 40px solid red square on a transparent background | | block-r.png<br/>block-b.png<br/>block-g.png || [[File:Block.png]] || a 40px solid red square on a transparent background with -r suffix. Also in blue and green (-b and -g suffixes) | ||
|- | |- | ||
| pling.png || [[File:Pling.png]] || a pointer style icon. Note: use '''"top":"-40px","left":"-13px"''' to have marker tip at the identified point | | pling.png || [[File:Pling.png]] || a pointer style icon. Note: use '''"top":"-40px","left":"-13px"''' to have marker tip at the identified point |
Revision as of 19:53, 7 January 2013
This is work in progress. Do not rely on this document just yet.
We expect to finalize this by the end of January 2013.
Introduction
In early 2013 we will be introducing a facility to annotate the University Map with your own information. Typically this will be done using a user interface (to follow), but for those who want to derive overlays programmatically from existing data or otherwise roll their own, this describes how.
Note: if all you want to do is create a link to show your department etc on the map, you don't need to create any annotation. Just use the link shown in your browser address bar when you are looking at the full results for the institution. For example: http://map.cam.ac.uk/Department+of+Geography . This also means if you move, the link will show up-to-date information without any changes.
GeoJSON
Overlays are specified using UCamGeoJSON, a file format based on GeoJSON (see specification), which in turn is based on the JSON file format. UcamGeoJSON differs in three respects from GeoJSON:
- It does not implement Co-ordinate Reference Systems. All points are given as latitude and longitude using the WGS84 datum.
- GeoJSON only provides geometry. UCamGeoJSON defines the recognized content of the properties element of Feature objects, used to define what the shapes are for: things like colour of shapes, what text and icons are to appear at points, and so on.
- Additional members of the top level JSON object z, pos and expand can be given, to set the initial view of the map (how far it is zoomed in, where it is centred, and whether it fills the browser window respectively). See Initial map view below.
Note that in JSON, unlike Javascript, key values must be included in double quotes, and comments are not permitted.
Using UCamGeoJSON
The map is told to overlay custom annotation by giving it some UCamGeoJSON data in the URL. This is done in the fragment part of the URL (that is, the bit after a '#'), like this:
http://map.cam.ac.uk/...#data
One can still include other parts of the URL as normal, for example to search for a particular institution. The whole of such URLs can be shortened using any shortening service, such as bit.ly.
The data can be included in one of three ways:
- Directly including UCamGeoJSON in the URL. This is only appropriate for small amounts, as length of URLs that browsers and other software can handle is limited. In practice, restrict the total length of URLs to under 2,000 characters. In this case the first character after the hash will always be '{'. In general, do not (percent) escape this part of the URL: see escaping.
- Referencing the UCamGeoJSON via a URL. The content provided by the URL is the UCamGeoJSON data, and the response to the request will use content-type 'application/json'. The URL will usually be absolute, that is start with 'http://', but in many cases it will be relative to the map itself, and therefore start with a '/' (see especially Adapters below). For example:
http://map.cam.ac.uk/#http://www.example.com/my-ucamgeojson.json http://map.cam.ac.uk/#/annotate/adapters/osm.json?src=http://www.example.com/my-osmfile.osm
- Do escape these embedded URLs properly, but don't double escape them.
- If your URL does not refer to the University's map server, you will have to consider cross site scripting restrictions otherwise your file may not be accessible to the map.
- Giving one, two or three numbers after the '#'. These are abbreviations for default zoom level, default map centre, or both, respectively (see below), thus:
http://map.cam.ac.uk/#z http://map.cam.ac.uk/#lat,lon http://map.cam.ac.uk/#lat,lon,z
- These are exactly equivalent to the following (respectively):
http://map.cam.ac.uk/#{"z":z} http://map.cam.ac.uk/#{"pos":{"type":"Point","coordinates":[lon,lat]}} http://map.cam.ac.uk/#{"pos":{"type":"Point","coordinates":[lon,lat]},"z":z}
escaping
Normally, unusual characters in URLs are "percent escaped". However, whatever the right or wrong answer with the fragment part, in practice every browser handles this differently, and they also behave differently between pasting or typing a link into the address bar and following a link in a web page. Furthermore most pattern recognition for URLs will stop when they see a '{' in the fragment, so in emails, for example, verbatim JOSM will probably not link correctly (but you could do this via a bit.ly link).
The most reliable answer is
- Don't escape the hash part at all.
- Do escape URLs within the hash part as normal (but don't double escape them).
When you quote or follow such a link, some browsers escape some, but not all, unusual characters - but then present them to the code without un-escaping them; others un-escape some escaped characters! For this reason, in order to get consistent results, the map will treat %NN where N is a digit as a sequence to be un-escaped, but otherwise treat % as a true percent sign, except within URLs.
Initial map view
The top level GeoJSON object may additionally contain some or all of the members z, pos, expand and nearby to control the initial map view. Indeed, any or all of these may be the entire content of the object if all you want to do is override the default view determined by the map automatically.
- z is the initial zoom level. For the University Map, the lowest zoom level (smallest scale, most zoomed out, when the scale on the map shows "2km") is 13 and the highest (largest scale, most zoomed in, when the scale shows "25m") is 19.
- pos is the point on which the map is initial centred. The value of pos is a GeoJSON Point object, that is it provides a latitude and longitude on which the map is to be centred.
- expand is a boolean value which (except for mobile devices with small screens) can be used to display the map with (false) the border content like the search box and search results list, or without (true) to fill the whole window.
- nearby is either a boolean value or a GeoJSON Point object. If a Point object, this causes the map to display institutions near to the Point. If true, then pos (which must be present) is used as the point. This is equivalent to the user choosing the 'nearby' function on the relevant point on the map before the annotation is displayed.
For example:
{ "pos": {"type":"Point", "coordinates":[52.2036,0.1202]}, "z": 19, "nearby": true, "type": "FeatureCollection", "features": [...] }
Properties
The content of the properties member of the GeoJSON Feature object is not defined by GeoJSON other than as a set of arbitrary key/value pairs. The intention is that these specify the appearance of the shapes described by the GeoJSON geometry.
UCamGeoJSON does define properties, as follows. In general the properties are a subset of CSS, so the detailed formats of each need not be defined here, only any special interpretation of them. Refer to CSS for the details. Many of these are indeed simply applied as CSS styles to the graphic objects created in the HTML DOM.
In broad terms, the geometry provides filled areas, lines and points.
Areas and lines are drawn by applying a few styling properties, such as color (note US spelling, as in CSS).
Points are represented by icons (images) and/or text drawn at the position indicated according to the style indicated by the properties. You can have both an icon and text at a single point. These are grouped into an HTML div (hereinafter the box), which allows for flexible and controllable layout using CSS.
properties applied to filled shapes and lines
Namely: shapes as GeoJSON Polygon and MultiPolygon objects and lines as LineString and MultiLineString objects.
Note: line and outline widths are in pixels at whatever zoom level they are displayed. The width of a line is invariant and does not scale according to the zoom level.
property name | filled shapes | lines | notes |
color | colour with which the shape is filled | colour in which the line is drawn (note: stroke-color overrides this) | any CSS colour specification is allowed, e.g. a name like 'green', hash and six hex digits, or 'rgb(...)' etc. Default is tomato (a bright-ish red). |
stroke-width | the width in pixels of a line drawn around the shape. If not given, or zero, no outline is drawn. | the width in pixels of the line | |
opacity | of the filled shape (and the outline, if stroke-opacity is not given separately). | of the line (note: ignored if stroke-opacity also given). | |
stroke-color | colour of line around the shape. | colour of the line | |
stroke-opacity | the opacity of line around the shape. | the opacity of the line | a number between zero and one e.g. 0.5. If not given, opacity is used in both cases (so if you just give opacity it applies to both the filled shape and its outline). |
stroke-linecap, stroke-linejoin, stroke-miterlimit |
specialized properties of line. | specialized properties of line | see the SVG specification for details of these |
stroke-dasharray | dash pattern for line around shape. | dash pattern of line | a string, one of "-", ".", "-.", "-..", ". ", "- ", "--", "- .", "--.", "--.." forming a mixture of dashes and dots accordingly. Note that this is not the same as the SVG property stroke-dasharray, but derives from the cross-browser Raphaël system (documentation). |
properties applied to both text and images
Namely, GeoJSON Point and MultiPoint objects.
Either text or an image or both may be displayed at a Point. This is done within a DIV box to which these properties are applied - see above.
The same content (typically several marker icons) is displayed for each point in a MultiPoint.
property name | meaning |
background, background-color | the background of the box. Default is transparent. |
border, border-color, border-width | the border styling of the box. For text and icons, note that with judicious use of border images and backgrounds, one can produce things like "speech bubbles" pointing at the map, a-la-Google maps. |
border-radius | of the box. Rounded corners don't work in older browsers. |
opacity | of the background of the box |
width, height | of the box; if you only give width, that means you can have a box which all the text fits in, but wraps when too wide to fit across. Note: the CSS unit "px" must be included, e.g. 10px, not just 10. |
overflow | of the box contents, defaults to hidden |
href | url: the whole of the box content will link to the given url |
top, left | the box is offset by the amounts given. This means you can center the content over the point rather than at the default top left corner. Note: the CSS unit "px" must be included, e.g. 10px, not just 10. Typically, these will be minus half the width and height, though for an arrow, for example, they might offset to the tip of the arrowhead. |
padding | around the inside of the box (pixels only) |
properties applied to images/icons/markers
property name | meaning |
src | url of icon (any image) to be displayed. Generally you will want this to have a transparent background and will typically use a PNG image. You could use an animated GIF if you insist! But probably not a JPG. A few ready made icons and markers are provided at http://map.cam.ac.uk/annotate/markers, though you can, of course, use any image accessible via http. |
title | the title attribute of the image (usually displayed by browsers in a 'tool tip' when hovering over it. |
img-width, img-height | width and height applied to the image including the 'px' unit (remember, width and height apply to the containing box). e.g 40px |
float | left, right: with both images and text floats the image to the left or right of the text within the box so the text wraps around it; otherwise the text starts underneath the image |
properties applied to text
property name | meaning |
content | Text string to be displayed. This is text, not HTML, and is encoded as UTF-8. If you need a line break, you need to provide it as a newline in the data (not <br/>). You can also cause strings to wrap if you use the width property, but where the break occurs is then not easily predictable. |
color | colour of the text; any CSS colour specification is allowed, e.g. a name like green, #ccaa12, or rgb(12,128,44) etc. Default is black. |
font-family | Just because you have a particular font installed on your computer doesn't mean the recipient has - so use web-safe fonts, e.g. Verdana, Tahoma, Trebuchet, Georgia, Times, Helvetica |
font-size | in pixels only, e.g. 12px |
font-weight, font-style, text-decoration, letter-spacing, word-spacing, line-height | per CSS |
text-align | center (US spelling), left, right within the box. This will also apply to any image which isn't floated. |
Markers
Several read-made markers are available for use with the src property, as follows. These are located in /annotate/markers, hence you might write:
"src": "/annotate/markers/circle.png"
Adapters
Though the map understands UCamGeoJSON, certain other formats can be managed using adapters. These are scripts which convert data (identified via their query strings etc) into UCamGeoJSON.
Some default scripts are provided at http://map.cam.ac.uk/annotate/adapters:
- University map, version 4: v4.json. version 4 applied limited annotation to its maps entirely within its URL query string; v4.json takes exactly the same query string and produces equivalent UCamGeoJSON.
- GBN: gbn.json. Reads the OpenStreetMap XML file containing Granta Backbone network description. For example:
http://map.cam.ac.uk/#/annotate/adapters/gbn.json
Other useful candidates would be: KML, GPX.
Of course, as the URL for UCamGeoJSON content is arbitrary, it is possible to provide other adapters on any web site.
URL referencing considerations
Login-protected sources
Sometimes overlays may be located on sites which require a login, especially when these are confidential.
Note, however, that Dropbox in particular now offers unprotected URLs to shared files, so by advertising that URL one can store overlays in a Dropbox folder.
Where a resource is Raven protected (perhaps further restricted to a particular Lookup group of people), this will be detected and you will be asked to log in to Raven and try again. For generic links, we will indicate that you may have to log in,but cannot tell you where. Paste your link into the browser and complete the login there, then try the map URL again.
Because the content is accessed by the browser, which is what your login applies to, and not by the server, your content should be accessible once you have logged in.
Cross-site scripting
If you use a URL to access JSON data and that URL indicates somewhere other than the University's map server, you have to consider cross site scripting restrictions.
In general, a web page from one server cannot request data from another, for security reasons. This means you will get an error if you naively use a non-map URL after the hash.
There are several ways in which this can be worked around.
- Use CORS. You need access to the web site files for the server providing the data for this to work. The server on which the data is stored responds with some additional information which says it is OK for the map to use the data. For Apache servers, (at least) the following can be put in a .htaccess file in the directory where the data is being retrieved from (whether the data is static file or scripted). This depends on the web server allowing these options to be set in .htaccess.
Header add Access-Control-Allow-Origin "*" Header add Access-Control-Allow-Headers "origin, x-requested-with, content-type" Header add Access-Control-Allow-Methods "GET"
- If you want to restrict the data only to the map, use http://map.cam.ac.uk instead of the asterisk in the first line (the asterisk means you are giving permission to any requesting page).
- Use a site that already has CORS turned on for you. That is, a storage provider who recognises that the data will be required by other sites. In this case you need do nothing, the request should just work.
- For example, Dropbox supports CORS, and you can also persuade Dropbox share a file via a link that doesn't require a Dropbox account or logging in, so this is ideal for these purposes.
- However, note that CORS is relatively new technology. It requires the user's browser to support CORS. Most browsers do, but notably the now rather-aged but still fairly widely used Internet Explorer 7 does not.
- Use the annotation adapter provided for the purpose:
...#/annotate/adapters/cors.json?url=your-url-here
- This has the effect of asking the map server to retrieve your file for you. However, this does not work with password protected sites, because even though you may have logged in, it is the map server asking for the data, not your own browser, so you will not be logged in.