In this section:
How to: |
To create a choropleth or bubblemap chart, you must specify the appropriate LOOKGRAPH parameter in your FOCUS request and you must add map properties to the *GRAPH_JS block in the StyleSheet.
You can also use several general chart properties to enhance the map charts.
To generate a choropleth chart, specify the following command in your FOCUS request:
ON GRAPH SET LOOKGRAPH CHOROPLETH
To generate a bubblemap chart, specify the following command in your FOCUS request:
ON GRAPH SET LOOKGRAPH BUBBLEMAP
where:
Fills specified regions of a map with heat-coded color values.
Draws circular bubbles on top of a map.
In the mapProperties object in the GRAPH_JS block of the StyleSheet, specify the map viewer engine (leaflet) and the map properties:
*GRAPH_JS
mapProperties: {
engine: 'leaflet',
leafLet:{
map_properties
}
}
*END
where:
Are the properties that control the map tiles, map overlays, and map controls in your chart.
You can also use an alternate map tiling engine.
How to: |
The following facts describe automatic positioning in map charts:
Instead, you can specify your own initial position and initial zoom level in the map properties included in your request.
initPos:{ center:[latitude, longitude], level: number}
where:
Are the latitude and longitude for the center position of the map.
Is the initial zoom level of the chart. Valid values are numbers from 1 (whole earth) to 19.
How to: |
You can specify an opacity (degree of transparency) for either a choropleth or bubblemap using the mapOpacity property.
In this section: |
You can control elements such as the chart legend, the map scale, and the allowed zoom levels of the map.
The legend can be formatted, moved, or hidden entirely. For information, see Legend Properties.
The scale control can be omitted or set to show miles, kilometers, or both. The layers control can be included or omitted. By default, both controls are shown on the output if the controls object is omitted from the leaflet block in the StyleSheet.
Add the controls object to the leaflet block of the StyleSheet:
leaflet:{ controls: [ {control: 'L.Control.Layers'}, {control: 'L.Control.Scale', options: { imperial: boolean1, metric: boolean2} } ], ... }
where:
Controls the display of miles. Valid values are:
Controls the display of kilometers. Valid values are:
For example, the following properties show both miles and kilometers on the scale:
leaflet: { controls: [ {control: 'L.Control.Layers'}, { control: 'L.Control.Scale', options: { imperial: true, metric: true } } ], ... }
The following properties cause the scale not to be shown at all:
leaflet: { controls: [ {control: 'L.Control.Layers'}, { } ], ... }
The following properties hide both the layers control and the scale control:
leaflet: { controls: [ ], ... }
How to: |
On a map chart, there is a base layer that displays the map tiles.
On top of the base layer, an overlay layer displays the FOCUS request output that either colors specified areas on the map or draws bubble markers on top of them.
FOCUS supports one base layer and one overlay layer.
FOCUS is licensed to access Esri ArcGIS maps, which exist on an Esri server. If you are licensed to use a different map provider, you can access their maps instead.
In addition, free Mapbox© OpenStreet© maps are installed with FOCUS. You can use them if you are not able to import the Esri maps into your system.
Since the maps displayed on any map chart are owned by the services that supply them, they require that you include a copyright attribution on your chart, which is one of the properties you must include in the base layer.
The connection between the map locations and the fields in your data source are implemented using a JSON or geoJSON location file. FOCUS supplies JSON location files, but you can add additional locations or different types of location files by adjusting the map properties to point to the files you want.
The location files contain lists of major political subdivisions (such as state and city) along with the latitudes and longitudes that define the borders of the primary subdivision (for example, in the USA, state).
The following code shows a snippet of the beginning of the US.JSON location file, which lists US cities and states. The primary layer (map subdivision) is called regions. The position property contains the latitude and longitude of the city:
"map_type":"country",
"country_name":"United States of America",
"iso_a2":"US",
"primary_layer":"regions",
"layers":[{
"type":"cities",
"geocode":["city_name"],
"units":"decimal_degrees",
"geometry_type":"point",
"primary_name_field":"city_name",
"features":[{
"city_name":"New York",
"rank":"0",
"region":"New York",
"position":[-73.98,40.7499],
"size":24.2
},
{ "city_name":"Washington, D.C.", "rank":"0", "region":"District of Columbia", "position":[-77.0094,38.8995], "size":22 }, { "city_name":"Los Angeles", "rank":"0", "region":"California", "position":[-118.1799,33.9899], "size":23.6
The following code shows the beginning of the state definitions. Note that the type is regions and the fields include state_name and state_abbr. Each state definition also includes latitudes and longitudes for its borders:
"type":"regions", "geocode":["state_abbr","state_name","state_fips","iso_3166_2"], "units":"decimal_degrees", "geometry_type":"polygon", "primary_name_field":"state_name", "primary_abbr_field":"state_abbr", "primary_id_field":"state_abbr", "features":[{ "state_name":"Hawaii", "state_abbr":"HI", "state_fips":"15", "iso_3166_2":"US-HI", "borders":[[[-155.9633,19.0815],[-155.9432,19.3442], [-156.1192,19.7364],[-155.8843,20.0183],[-155.959,20.2268], [-155.8367,20.3212],[-155.1403,19.9894],[-154.7566,19.5069], [-154.9396,19.3128],[-155.466,19.0953],[-155.649,18.8705]], [[-156.5651,20.7389],[-156.7519,20.9136],[-156.6058,21.0925], [-156.451,20.9687],[-156.2685,21.0037],[-155.9589,20.875], [-155.9267,20.7817],[-156.0299,20.604],[-156.375,20.5289], [-156.4845,20.579],[-156.5334,20.4629],[-156.75,20.4543], [-156.7336,20.5818],[-156.4957,20.6915]],[[-158.3176,21.5391], [-158.3242,21.6156],[-157.9417,21.7545],[-157.6505,21.485], [-157.6009,21.2829],[-157.8102,21.1992],[-158.1347,21.2423]], [[-159.7936,21.9397],[-159.8481,22.076],[-159.6129,22.2722], [-159.3896,22.2875],[-159.25,22.1757],[-159.2843,21.9406], [-159.4328,21.8207]],[[-157.015,21.2611],[-156.722,21.226], [-156.6527,21.125],[-156.8779,20.9933],[-157.3637,21.0923], [-157.2812,21.2725]],[[-175.9394,27.6882],[-176.0396,27.7582], [-175.921,27.8214],[-175.9814,27.9132],[-175.7043,27.9827], [-175.7341,27.7388]],[[-157,20.6968],[-157.1112,20.9312], [-156.8684,20.9643],[-156.75,20.8076],[-156.875,20.6909]], [[-160.2589,21.7428],[-160.2799,21.9206],[-160.0634,22.0726], [-160.031,21.8693]],[[-166.1722,23.587],[-166.3844,23.8319], [-166.307,23.9248],[-166.1823,23.9023],[-166.1067,23.7425]], [[-178.3014,28.3283],[-178.4404,28.4051],[-178.375,28.51], [-178.2384,28.4561]],[[-174.0064,25.9902],[-174.0547,26.1077], [-173.9579,26.1356],[-173.9033,26.06]],[[-171.7374,25.7065], [-171.8096,25.7813],[-171.75,25.8379],[-171.6679,25.7812]], [[-161.9318,23.0053],[-161.9825,23.0912],[-161.8875,23.1103]], [[-164.723,23.5217],[-164.7611,23.5934],[-164.6826,23.6228], [-164.6453,23.5515]],[[-160.5707,21.6066],[-160.5918,21.6858], [-160.5087,21.7032],[-160.4849,21.6324]],[[-168.0235,24.9544], [-168,25.0522],[-167.9442,24.9898]]] },
In order to connect the map data with the data in your data source, you must identify the type of subdivision you are using and the field in the location file that has the same data as the sort field in your FOCUS request. For example, using this location file, if your data source has state names, you must identify regions as the type of subdivision to use and state_name as the field name to use from the location file.
mapProperties:{ baselayers: [{ title: 'string', layerInfo: { maxZoom: number, minZoom: number, attribution: function(){ return "&|copy; <a target='_blank' href='http://www.InformationBuilders.com'>Information Builders</a> | " + "Map Tiles: &|copy; Esri";} }, url: function(){return 'http://services.arcgisonline.com/ArcGIS/rest/services/World_Street_Map/MapServer/tile/{z}/{y}/{x}'; } }] }
where:
Is a title for the layer. This title appears when you click the layer control displayed at the top right of the map.
Is the value -1 (fully automatic) or a number between 1 and 19 that defines the maximum zoom level allowed.
Is the value -1 (fully automatic) or a number between 1 and 19 that defines the minimum zoom level allowed.
Defines the initial zoom and center of the returned map service.
Is the initial zoom level, specified in the initPos:level property,
Is the latitude for the center of the initial view, specified in the initPos:center property,
Is the longitude of the initial view, specified in the initPos:center property,
Note:
The following are different types of maps provided by Esri and the url references needed to access them:
http://services.arcgisonline.com/ArcGIS/rest/services/World_Street_Map/MapServer/tile/{z}/{y}/{x}; http://services.arcgisonline.com/ArcGIS/rest/services/World_Topo_Map/MapServer/tile/{z}/{y}/{x}; http://services.arcgisonline.com/ArcGIS/rest/services/World_Imagery/MapServer/tile/{z}/{y}/{x}; http://services.arcgisonline.com/ArcGIS/rest/services/World_Terrain_Base/MapServer/tile/{z}/{y}/{x}; http://services.arcgisonline.com/ArcGIS/rest/services/Canvas/World_Light_Gray_Base/MapServer/tile/{z}/{y}/{x}; http://services.arcgisonline.com/ArcGIS/rest/services/NatGeo_World_Map/MapServer/tile/{z}/{y}/{x}; http://services.arcgisonline.com/ArcGIS/rest/services/Ocean_Basemap/MapServer/tile/{z}/{y}/{x};
The following code shows the attribution and url properties for using the OpenStreetMap maps installed with FOCUS:
attribution: function(){ return '&|copy; <a href="http://www.ibi.com">IBI</a> | ' + 'Map data &|copy; <a href="http://www.openstreetmap.org/copyright">OpenStreetMap</a> contributors, Open Database Licence';} }, url: function(){ return tdgchart.getScriptPath().replace(/\/tdg\/.*/,'') + '/maptiles/osm/{z}/{x}/{y}.png'}
The following code shows the attribution and url for another type of OpenStreet map provided by Mapbox, available out of the box:
attribution: "Map data &|copy; <a href='http://www.openstreetmap.org/copyright'>OpenStreetMap</a> contributors, Open Database Licence | Map Tiles by <a href='http://mapbox.com'>Mapbox</a>",
url: 'http://{s}.tiles.mapbox.com/v3/bclc-apec.map-rslgvy56/{z}/{x}/{y}.png',
The following request sets an initial position and zoom level and generates the map base layer.
Note: Due to their length, certain lines of syntax in the example below may wrap onto the next line of text. Wrapping may create breaks within strings or url references, which may cause errors when run. If you copy and paste this example, be sure to remove these line breaks before running it.
GRAPH FILE WFLITE SUM MDN.STATE_PROV_POPULATION BY STATE_PROV_NAME WHERE COUNTRY_NAME EQ 'United States' WHERE STATE_PROV_NAME NE 'Puerto Rico' ON GRAPH HOLD FORMAT JSCHART ON GRAPH SET LOOKGRAPH CHOROPLETH ON GRAPH SET STYLE * *GRAPH_JS mapProperties: { engine: 'leaflet', leaflet: { initPos: { center: [37.8, -96], level: 4 }, baselayers: [{ title: "ArcGIS_World_Street_Map", layerInfo: { maxZoom: 17, minZoom: 0, attribution: function(){return "&|copy; <a target='_blank' href='http://www.InformationBuilders.com'>Information Builders</a> | " + "Map Tiles: &|copy; Esri";} }, url: function(){return 'http://services.arcgisonline.com/ArcGIS/rest/services/World_Street_Map/MapServer/tile/{z}/{y}/{x}'; } }] } }, *END ENDSTYLE END
On the resulting map, the request output is not represented, as that would go on the overlay layer:
mapProperties:{ overlayLayers: [{ title: 'string', dataLookup: 'properties.field', layerInfo: { maxZoom: number, minZoom: number, type: 'string' }, type: 'string', url: function(){ return tdgchart.getScriptPath() + 'map/location.json'} }] }
where:
Is a title for the layer. This title appears when you click the layer control displayed at the top right of the map.
Is the name of the field in the location file that contains the same data as the sort value in your request. Not required for a latitude/longitude-based map layer.
Defines the minimum zoom, the maximum zoom, and the type of data being returned.
Is the value -1 (fully automatic) or a number between 1 and 19 that defines the maximum zoom level allowed.
Is the value -1 (fully automatic) or a number between 1 and 19 that defines the minimum zoom level allowed.
Is the type of geographical subdivision as listed in the location file.
Defines the type of location file being used. Valid values are:
Defines the map location file being returned.
Is the name of the location file, for example, US.JSON. If you are using geoJSON files or additional territories not supplied with FOCUS, change the extension to the correct value and point to where these files are stored.
Note:
The following code shows how to use the location file sample_ggsales_regsions.geojson, that was installed as a sample during FOCUS installation:
url: function() { return tdgchart.getScriptPath().replace(/\/tdg\/.*/,'/web_resource/map/') +'sample_ggsales_regions.geojson'}
The following request defines an overlay layer and the layer and scale controls. The type property is set to 'regions' and the dataLookup property is set to 'properties.state_name' because these are the values specified in the location file that match the data in the WFLITE data source.
Note: Due to their length, certain lines of syntax in the example below may wrap onto the next line of text. Wrapping may create breaks within strings or url references, which may cause errors when run. If you copy and paste this example, be sure to remove these line breaks before running it.
GRAPH FILE WFLITE SUM MDN.STATE_PROV_POPULATION BY STATE_PROV_NAME WHERE COUNTRY_NAME EQ 'United States' WHERE STATE_PROV_NAME NE 'Puerto Rico' ON GRAPH HOLD FORMAT JSCHART ON GRAPH SET LOOKGRAPH CHOROPLETH ON GRAPH SET STYLE * *GRAPH_JS mapProperties: { engine: 'leaflet', leaflet: { initPos: { center: [37.8, -96], level: 4 },
overlayLayers: [{ title: 'United States of America', dataLookup: 'properties.state_name', layerInfo: { maxZoom: -1, minZoom: -1, type: 'regions' }, type: 'tdg', url: function(){ return tdgchart.getScriptPath() + 'map/US.json'} }], controls: [ {control: 'L.Control.Layers'}, { control: 'L.Control.Scale', options: { imperial: true, metric: true } } ],
baselayers: [{ title: "ArcGIS_World_Street_Map", layerInfo: { maxZoom: 17, minZoom: 0, attribution: function(){ return "&|copy; <a target='_blank' href='http://www.InformationBuilders.com'>Information Builders</a> | " + "Map Tiles: &|copy; Esri";} }, url: function(){return 'http://services.arcgisonline.com/ArcGIS/rest/services/World_Street_Map/MapServer/tile/{z}/{y}/{x}'; } }] } }, *END ENDSTYLE END
The request output is a choropleth on top of the base layer, in which the median populations are defined by the colors of the polygons representing the different states:
When the mouse hovers over the layer control, the title for each layer displays:
On this choropleth, there is no indication of the population values that the colors represent or the actual values for each state. You can add these objects using the legend and tooltip properties.
Information Builders |