Starting today, customers can now cluster tiled data directly via the Mapbox Tiling Service (MTS) using recipe features. Developers no longer need to pre-cluster source data or use legacy tools like Tippecanoe to create clustered tilesets. The new clustering capability of MTS makes it easier to consolidate and streamline data pipelines.
Visualize high point count, low zoom level datasets
MTS clustering enables cluster circle and heatmap data visualizations for high point count, low zoom level datasets without dropped or missing features. This makes it easier to avoid hitting layer size limits at lower zoom levels for high-point count datasets. For example, developers can create circle clusters of available parking spots for an entire continent or large country at zoom level 4. Developers could also create a heatmap of the value of their real estate portfolio across the entire United States that’s visible even at zoom level 3, with no missing properties.
data:image/s3,"s3://crabby-images/286f2/286f25140c2f294980b6a097ed654a085644c6c3" alt=""
Real estate organizations could cluster their national listings database in internal dashboards to help with analysis. Travel planning sites could cluster hotel listings by city or country to give users a bird’s eye view of hotel availability when planning a trip.
data:image/s3,"s3://crabby-images/e7ecc/e7ecc058c4e5dc29f7b181db42edc0fccc3563ea" alt=""
data:image/s3,"s3://crabby-images/f0675/f0675155482c4a6b1a32a20a427e7a72baba0e8b" alt=""
Propertium.io recently adopted clustering for their real estate map.
“Displaying over one million real estate properties across Portugal, Spain, Bulgaria, Poland, and other European countries was a complex challenge. The sheer amount of data we process at Propertium.io — literally gigabytes spanning entire nations—made map loading, panning, and zooming slow and cumbersome. Without clustering, the experience was far from seamless.”
"To solve this, we implemented MTS clustering in just 60 minutes with a quick and effective recipe change. Now, investors using Propertium.io can instantly see, at a glance, the best locations for high-ROI real estate opportunities. Whether it’s properties in Lisbon, Madrid, Sofia, Warsaw, or beyond, the platform empowers them with the speed and insights needed to make smarter investment decisions." -Nikita Navalikhin, Founder, Propertium.io
data:image/s3,"s3://crabby-images/7778c/7778c320d84fc9df33c0f067ccfd3e062a6a8405" alt=""
data:image/s3,"s3://crabby-images/996df/996dfe1d6cdbaacdef8c70b5c7f61e0f0b37410d" alt=""
There are two steps to creating a cluster data visualization using MTS:
Step 1: Cluster data with MTS
To cluster data with MTS:
- Set a
count
feature attribute with a value of 1 for each point - Configure the cluster field in the tiles configuration
Step 1 - Set the count feature attribute
First, add a feature attribute called count
to the feature configuration of your MTS recipe. Set the value of this feature attribute to 1. MTS will sum each point to create the cluster point count.
Step 2 - Union points via clustering
Second, add a union object to the tile configuration of the MTS recipe and set cluster
to true
. Use an empty group_by ("group_by": [])
to union all features (e.g., points to be clustered) regardless of their attributes. Set the region_count to the number of clustered points needed for each tile. The region_count
must be a power of 4 between 1 and 16,384, so valid values are 1, 4, 16, 64, 256, 1024, 4096,
or 16384.
Finally, use an aggregate rule to sum the count for each point to create the point count for the cluster. It’s possible to add additional aggregate rules here for other feature attributes to use in clustering or heatmap data visualizations. For example, calculate the total property value for a real estate footprint dataset or the total population for a cities dataset.
Final recipe
The final clustering MTS recipe will look like this:
Step 2: Style clustered data
After publishing the tileset, there will be a set of evenly spaced points in the Tileset Explorer. While these points do not look like clusters yet, the data is structured to enable data-driven styling with just a few additional steps.
data:image/s3,"s3://crabby-images/9f2b2/9f2b242883d5d14d2c5f953cd8b11e47b9fddcf3" alt=""
To create clusters, use data-driven styling with either a circle layer or a heatmap layer. A circle layer creates a traditional cluster map with different-sized and colored circles based on the point count of a cluster. Or use a heatmap layer instead, which uses a range of colors to show density.
The code samples below use Mapbox GL JS. Mapbox Studio and the Mapbox Mobile Maps SDKs for iOS and Android also support creating circle and heatmap layers.
Create a traditional cluster circle layer with data-driven styling
data:image/s3,"s3://crabby-images/47547/47547a112aa2190c3fc18307bdb21290e0918d99" alt=""
The Mapbox GL JS code sample below uses data-driven styling of a circle layer using the point count of the cluster. Clusters with a point count of 2 or less are blue circles with a 3px radius, point counts between 2-10 are yellow circles with a 5px radius, and point counts of 10 or greater are pink circles with a 10 px radius.
Create a heatmap with clustered tileset data
data:image/s3,"s3://crabby-images/c9c4c/c9c4cddd74b3807a81fbe5bcc75204c43f91f051" alt=""
The Mapbox GL JS code sample below uses a heatmap layer to display clustered points. The Make a heatmap with Mapbox GL JS tutorial describes in depth how to modify the heatmap paint properties for the data source.
Consistently improving the Mapbox Tiling Service
MTS clustering is available today for all MTS customers at no additional cost. Check out the MTS documentation to learn more about MTS.
Clustering is one of many recent improvements to the Mapbox Tiling Service, including support for raster data and multi-region architecture for reliability and compliance. Check out the raster MTS documentation to get started. To learn more about multi-region MTS, email Mapbox at mts-multi-region@mapbox.com.
data:image/s3,"s3://crabby-images/00d09/00d09afcba849ef4d90f8db273fa17c96838bd3a" alt=""