[ Main Table Of Contents | Table Of Contents | Keyword Index | Categories | Modules | Applications ]
NAME
map::slippy - Common code for slippy based map packages
Table Of Contents
SYNOPSIS
package require Tcl 8.6 9
package require map::slippy ?0.10?
::map slippy geo box 2point zoom geobox
::map slippy geo box center geobox
::map slippy geo box corners geobox
::map slippy geo box diameter geobox
::map slippy geo box dimensions geobox
::map slippy geo box fit geobox canvdim zmax ?zmin?
::map slippy geo box inside geobox geo
::map slippy geo box limit geobox
::map slippy geo box opposites geobox
::map slippy geo box perimeter geobox
::map slippy geo box valid geobox
::map slippy geo box valid-list geoboxes
::map slippy geo distance geo1 geo2
::map slippy geo distance* closed geo...
::map slippy geo distance-list closed geo-list
::map slippy geo limit geo
::map slippy geo bbox geo...
::map slippy geo bbox-list geo-list
::map slippy geo center geo...
::map slippy geo center-list geo-list
::map slippy geo diameter geo...
::map slippy geo diameter-list geo-list
::map slippy geo 2point zoom geo
::map slippy geo 2point* zoom geo...
::map slippy geo 2point-list zoom geo-list
::map slippy geo valid geo
::map slippy geo valid-list geos
::map slippy length level
::map slippy limit2 x
::map slippy limit3 x
::map slippy limit6 x
::map slippy point box 2geo zoom pointbox
::map slippy point box center pointbox
::map slippy point box corners pointbox
::map slippy point box diameter pointbox
::map slippy point box dimensions pointbox
::map slippy point box inside pointbox point
::map slippy point box opposites pointbox
::map slippy point box perimeter pointbox
::map slippy point distance point1 point2
::map slippy point distance* closed point...
::map slippy point distance-list closed point-list
::map slippy point bbox point...
::map slippy point bbox-list point-list
::map slippy point center point...
::map slippy point center-list point-list
::map slippy point diameter point...
::map slippy point diameter-list point-list
::map slippy point 2geo zoom point
::map slippy point 2geo* zoom point...
::map slippy point 2geo-list zoom point-list
::map slippy point simplify radial threshold point-list
::map slippy point simplify rdp point-list
::map slippy pretty-distance x
::map slippy tiles level
::map slippy tile size
::map slippy tile valid zoom row column levels ?msgvar?
::map slippy valid latitude x
::map slippy valid longitude x
DESCRIPTION
This package provides a number of methods doing things needed by all types of slippy-based map packages.
BEWARE, Attention Version 0.9 is NOT backward compatible with version 0.7 and earlier. The entire API was heavily revised and changed.
Note: For the representation of locations in the various coordinate systems used by the commands of this package please read section Coordinate systems. The command descriptions will not repeat them, and assume that they are understood already.
Coordinate systems
The commands of this package operate in two distinct coordinate systems, geographical locations, and points. The former represents coordinates for locations on Earth, while the latter is for use on Tk canvas widgets.
Geographic
Geographical locations (short: geo) are represented by a pair of Latitude and Longitude values, each of which is measured in degrees, as they are essentially angles.
The Zero longitude is the Greenwich meridian, with positive values going east, and negative values going west, for a total range of +/- 180 degrees. Note that +180 and -180 longitude are the same meridian, opposite to Greenwich.
The zero latitude is the Equator, with positive values going north and negative values going south. While the true range is +/- 90 degrees the projection used by the package requires us to cap the range at roughly +/- 85.05112877983284 degrees. This means that the North and South poles are not representable and not part of any map.
A geographical location is represented by a list containing two values, the latitude, and longitude of the location, in this order.
A geographical bounding box is represented by a list containing four values, the minimal latitude and longitude of the box, and the maximal latitude and longitude of the box, in this order.
Geographical locations and boxes can be converted to points and their boxes by means of an additional parameter, the zoom level. This parameter indicates the size of the map in the canvas the coordinates are to be projected into.
Points
Points (short: point) are represented by a pair of x and y values, each of which is measured in pixels. They reference a location in a Tk canvas widget. As a map can be shown at different degrees of magnification, the exact pixel coordinates for a geographical location depend on this zoom level.
For the following explanation to make sense it should be noted that a map shown in a Tk canvas widget is split into equal-sized quadratic tiles.
Point coordinates are tile coordinates scaled by the size of these tiles. This package uses tiles of size 256, which is the standard size used by many online servers providing map tiles of some kind or other.
A point is represented by a list containing the x- and y-coordinates of the lcoation, in this in this order.
A point bounding box is represented by a list containing four values, the minimal x and y of the box, and the maximal x and y of the box, in this order.
Point locations and boxes can be converted to geographical locations and their boxes by means of an additional parameter, the zoom level. This parameter indicates the size of the map in the canvas the coordinates are projected from.
Tile coordinates appear only in one place of the API, in the signature of command map slippy tile valid. Everything else uses Point coordinates.
Using tile coordinates in the following however makes the structure of the map at the various zoom levels (maginification factors) easier to explain.
Generally the integer part of the tile coordinates represent the row and column number of a tile of the map, wheras the fractional parts signal how far inside that tile the location in question is, with pure integer coordinates (no fractional part) representing the upper left corner of a tile.
The zero point of the map is at the upper left corner, regardless of zoom level, with larger coordinates going right (east) and down (south), and smaller coordinates going left (west) and up (north). Again regardless of zoom level.
Negative coordinates are not allowed.
At zoom level 0 the entire map is represented by a single tile, putting the geographic zero at 1/2, 1/2 in terms of tile coordinates, and the range of tile coordinates as [0...1].
When going from zoom level N to the next deeper (magnified) level (N+1) each tile of level N is split into its four quadrants, which then are the tiles of level N+1.
This means that at zoom level N the map is sliced (horizontally and vertically) into 2^N rows and columns, for a total of 4^N tiles, with the tile coordinates ranging from 0 to 2^N+1.
API
::map slippy geo box 2point zoom geobox
The command converts the geographical box geobox to a point box in the canvas, for the specified zoom level, and returns that box.
::map slippy geo box center geobox
The command returns the center of the geographical box geobox.
::map slippy geo box corners geobox
This command returns a list containing the four corner locations implied by the geographical box geobox. The four points are top-left, bottom-left, top-right, and bottom-right, in that order.
::map slippy geo box diameter geobox
The command returns the diameter of the geographical box geobox, in meters.
::map slippy geo box dimensions geobox
The command returns the dimensions of the geographical box geobox, width and height, in this order.
::map slippy geo box fit geobox canvdim zmax ?zmin?
This command calculates the zoom level such that the geobox will fit into a viewport given by canvdim (a 2-element list containing the width and height of said viewport) and returns it.
The zoom level will be made to fit within the range zmin...zmax. When zmin is not specified it will default to 0.
::map slippy geo box inside geobox geo
The command tests if the geographical location geo is contained in the geographical box geobox or not. It returns true if so, and false else.
::map slippy geo box limit geobox
This command limits the geographical box to at most 6 decimals and returns the result.
For geographical coordinates 6 decimals is roughly equivalent to a grid of 11.1 cm.
::map slippy geo box opposites geobox
This command returns a list containing the two principal corner locations implied by the geographical box geobox. The two points are top-left, and bottom-right, in that order.
::map slippy geo box perimeter geobox
The command returns the perimeter of the geographical box geobox, in meters.
::map slippy geo box valid geobox
This commands tests if the specified geographical box contains only valid latitudes and longitudes. It returns true if the box is valid, and false else.
::map slippy geo box valid-list geoboxes
This commands tests if the list of geographical boxes contains only valid latitudes and longitudes. It returns true if all the boxes are valid, and false else.
::map slippy geo distance geo1 geo2
This command computes the great-circle distance between the two geographical locations in meters and returns that value.
The code is based on https://wiki.tcl-lang.org/page/geodesy take on the haversine formula.
::map slippy geo distance* closed geo...
An extension of map slippy geo distance this command computes the cumulative distance along the path specified by the ordered set of geographical locations in meters, and returns it.
If the path is marked as closed (i.e. a polygon/loop) the result contains the distance between last and first element of the path as well, making the result the length of the perimeter of the area described by the locations.
::map slippy geo distance-list closed geo-list
As a variant of map slippy geo distance* this command takes the path to compute the length of as a single list of geographical locations, instead of a varying number of arguments.
-
This command limits the geographical location to at most 6 decimals and returns the result.
For geographical coordinates 6 decimals is roughly equivalent to a grid of 11.1 cm.
::map slippy geo bbox-list geo-list
These two commands compute the bounding box for the specified set of geographical locations and return a geographical box.
When no geographical locations are specified the box is "0 0 0 0".
The locations are specified as either a varying number of arguments, or as a single list.
::map slippy geo center-list geo-list
These two commands compute the center of the bounding box for the specified set of geographical locations.
When no geographical locations are specified the center is "0 0".
The locations are specified as either a varying number of arguments, or as a single list.
::map slippy geo diameter-list geo-list
These two commands compute the diameter for the specified set of geographical locations, in meters. The diameter is the maximum of the pair-wise distances between all locations.
When less than two geographical locations are specified the diameter is "0".
The locations are specified as either a varying number of arguments, or as a single list.
::map slippy geo 2point zoom geo
This command converts the geographical location geo to a point in the canvas, for the specified zoom level, and returns that point.
::map slippy geo 2point-list zoom geo-list
These two commands are extensions of map slippy geo 2point which take a series of geographical locations as either a varying number of arguments or a single list, convert them all to points as per the specified zoom level and return a list of the results.
-
This commands tests if the specified geographical location contains only valid latitudes and longitudes. It returns true if the location is valid, and false else.
::map slippy geo valid-list geos
This commands tests if the list of geographical locations contains only valid latitudes and longitudes. It returns true if all the locations are valid, and false else.
-
This command returns the width/height of a slippy-based map at the specified zoom level, in pixels. This is, in essence, the result of
expr { [tiles $level] * [tile size] }
-
This command limits the value to at most 2, 3, or 6 decimals and returns the result.
For geographical coordinates 6 decimals is roughly equivalent to a grid of 11.1 cm.
::map slippy point box 2geo zoom pointbox
The command converts the point box pointbox to a geographical box in the canvas, as per the specified zoom level, and returns that box.
::map slippy point box center pointbox
The command returns the center of the pointbox.
::map slippy point box corners pointbox
This command returns a list containing the four corner locations implied by the point box pointbox. The four points are top-left, bottom-left, top-right, and bottom-right, in that order.
::map slippy point box diameter pointbox
The command returns the diameter of the pointbox, in pixels.
::map slippy point box dimensions pointbox
The command returns the dimensions of the pointbox, width and height, in this order.
::map slippy point box inside pointbox point
The command tests if the point is contained in the pointbox or not. It returns true if so, and false else.
::map slippy point box opposites pointbox
This command returns a list containing the two principal corner locations implied by the point box pointbox. The two points are top-left, and bottom-right, in that order.
::map slippy point box perimeter pointbox
The command returns the perimeter of the pointbox, in pixels.
::map slippy point distance point1 point2
This command computes the euclidena distance between the two points in pixels and returns that value.
::map slippy point distance* closed point...
An extension of map slippy point distance this command computes the cumulative distance along the path specified by the ordered set of points, and returns it.
If the path is marked as closed (i.e. a polygon/loop) the result contains the distance between last and first element of the path as well, making the result the length of the perimeter of the area described by the locations.
::map slippy point distance-list closed point-list
As a variant of map slippy point distance* this command takes the path to compute the length of as a single list of points, instead of a varying number of arguments.
::map slippy point bbox-list point-list
These two commands compute the bounding box for the specified set of points and return a point box.
When no points are specified the box is "0 0 0 0".
The locations are specified as either a varying number of arguments, or as a single list.
::map slippy point center-list point-list
These two commands compute the center of the bounding box for the specified set of points.
When no points are specified the center is "0 0".
The locations are specified as either a varying number of arguments, or as a single list.
::map slippy point diameter-list point-list
These two commands compute the diameter for the specified set of points, in pixels. The diameter is the maximum of the pair-wise distances between all locations.
When less than two points are specified the diameter is "0".
The locations are specified as either a varying number of arguments, or as a single list.
::map slippy point 2geo zoom point
This command converts the point in the canvas, for the specified zoom level, to a geograhical location, and returns that location.
::map slippy point 2geo-list zoom point-list
These two commands are extensions of map slippy point 2geo which take a series of points as either a varying number of arguments or a single list, convert them all to geographical locations as per the specified zoom level and return a list of the results.
::map slippy point simplify radial threshold point-list
This command takes a path of points (as a single list), simplifies the path using the Radial Distance algorithm and returns the simplified path as list of points.
In essence the algorithm keeps only the first of adjacent points nearer to that first point than the threshold, and drops the others.
::map slippy point simplify rdp point-list
This command takes a patch of points (as a single list), simplifies it using the non-parametric Ramer-Douglas-Peucker algorithm and returns the simplified path as list of points.
::map slippy pretty-distance x
This methods formats the distance x (in meters) for display and returns the resulting string (including the chosen unit).
Sub-kilometer distances are limited to 2 decimals, i.e. centimeters, whereas Kilometers are limited to 3 decimals, i.e. meters.
-
This command returns the width/height of a slippy-based map at the specified zoom level, in tiles.
-
This command returns the width/height of a tile in a slippy-based map, in pixels.
::map slippy tile valid zoom row column levels ?msgvar?
This command checks if the tile described by zoom, row, and column is valid for a slippy-based map having that many zoom levels, or not. The result is a boolean value, true if the tile is valid, and false otherwise. In the latter case a message is left in the variable named by msgvar, should it be specified.
-
This commands tests if the argument x is a valid latitude value, and returns the boolean result of that test. I.e. true if the value is valid, and false else.
::map slippy valid longitude x
This commands tests if the argument x is a valid longitude value, and returns the boolean result of that test. I.e. true if the value is valid, and false else.
References
KEYWORDS
geodesy, geography, latitute, location, longitude, map, slippy, zoom