Skip to main content

Draw Custom Shape Mode ⭐

Custom Shape Mode allows you to create predefined shapes on the map by selecting from available options. This mode is ideal for adding consistent and reusable shapes without the need to manually define each vertex.

You can handle Draw Custom Shape Mode like this:

map.gm.enableDraw("custom_shape");
map.gm.disableDraw();
map.gm.toggleDraw("custom_shape");
map.gm.drawEnabled("custom_shape");

// Or like this:
map.gm.enableMode("draw", "custom_shape");
map.gm.disableMode("draw", "custom_shape");
map.gm.toggleMode("draw", "custom_shape");
map.gm.isModeEnabled("draw", "custom_shape");

The following events are available on a map instance:

EventParamsDescriptionOutput
gm:drawstarteventFired when custom shape drawing starts.map, shape
gm:createeventFired when a custom shape is created.map, shape, feature

Customizing Custom Shape Behavior

You can customize the custom shape drawing behavior by defining the available shapes and their configurations. This allows you to offer different predefined shapes that users can select and draw on the map.

Example configuration:

const customShapeTriangle = {
type: "Feature",
properties: {
shape: "triangle",
},
geometry: {
type: "Polygon",
coordinates: [
[
[4.0, 51.2],
[5.4, 52.4],
[6.8, 51.2],
[4.0, 51.2],
],
],
},
};

const customShapeRectangle = {
type: "Feature",
properties: {
shape: "rectangle",
},
geometry: {
type: "Polygon",
coordinates: [
[
[-0.47, 51.67],
[1.43, 51.67],
[1.43, 53.32],
[-0.47, 53.32],
[-0.47, 51.67],
],
],
},
};

map.gm.options.controls.draw.custom_shape.options = [
{
type: "select",
label: "Shape",
name: "shape",
value: { title: "Triangle", value: JSON.stringify(customShapeTriangle) },
choices: [
{ title: "Triangle", value: JSON.stringify(customShapeTriangle) },
{ title: "Rectangle", value: JSON.stringify(customShapeRectangle) },
],
},
];

Live Draw Custom Shape Example