Skip to main content
Version: 4.0

Flat Labels

In Mappedin JS version 4, we brought back official support to what used to be called Legacy Labels and renamed them more descriptively to Flat Labels. We can add the Flat labels with default styles easily with mapView.labelAllLocations({flatLabels: true}).

Styling Flat labels

The following type declaration of appearance object describes the customizable attributes of Flat labels.

  • Height is the upper bounds of the Polygon by default. If you don't have a Polygon, or want a custom height for some reason, you can set this.
  • Margin is the amount of space to leave before starting the text from the edge of the bound of the canvas bound. These bounds are set in the Mappedin CMS. The default value is 5 pixels.
  • Color is a string format of a hexadecimal color representation such as #ff00000 for red.
  • fontSize in pixels, by default 12
  • Font can be set as a CSS style string font. ie "sans-serif". You can specify your own font via @font-face rule with a font family, and then include that here.
  • scaleMin sets the the minimum percentage we can shrink the label to if it won't fit within the bounds at 100%. If it doesn't fit at that level, it won't be created.
  • scaleStep describes how much to decrement the scale each time it doesn't fit, so we don't end up with too many different font sizes on screen at once. If you are only labeling a few Polygons rather than everything, you can set this and and scaleMin to 0.1 to fit everything except really long names perfectly. The default value is 0.25
export type TFlatLabelAppearance = {
height?: number;
margin?: number;
color?: string;
fontSize?: number;
font?: string;
scaleMin?: number;
scaleStep?: number;
};

Adding the appearance settings in our labelAllLocations -call, we can easily change the font, text color and increase the size to fit our brand style better.

mapView.labelAllLocations({
flatLabels: true,
appearance: {
font: 'Georgia',
fontSize: 16,
color: '#1c1c43',
},
});