Adjust marker placement in polygon symbols

This sample demonstrates how to adjust marker placement properties of a CIMSymbol and draw those symbols on a map using the SketchViewModel.

To modify the symbol properties in the app, either select the graphic already drawn in the view, or use the sketch tools in the top right to draw a new polygon. The panel options allow you to select a polygon style, update basic symbol properties such as color and size, and change the marker placement of the symbol.

Select a graphic in the view and change some of these properties to see them update in real time. Use the code icon in the top right of the UI to view the JSON of the CIMSymbol. You can copy this JSON and paste it into another app build with the ArcGIS Maps SDK for JavaScript, as shown in the code snippet below.

Use dark colors for code blocksCopy
1
2
3
const symbol = new CIMSymbol({
  data: // paste symbol JSON here
});

How this sample works

Each of the symbols in the gallery under Choose a polygon style are created from WebStyleSymbols.

WebStyleSymbols are predefined vector symbols that can be published from ArcGIS Pro and conveniently referenced in a web app with a simple reference to a symbol name and a style name.

Use dark colors for code blocksCopy
1
2
3
4
const webStyleSymbol = new WebStyleSymbol({
  name: "Airport",
  styleName: "EsriIconsStyle"
});

Each WebStyleSymbol is simply a wrapper to a full-fledged CIMSymbol. You can convert any WebStyleSymbol to its CIMSymbol representation using the fetchCIMSymbol method. Fetching the CIMSymbol allows you to access properties not available on the WebStyleSymbol, such as marker placement.

Using cimSymbolUtils

Under the Basic symbol properties accordion, you can adjust the size and color of the selected CIMSymbol. The utility methods in cimSymbolUtils help make updating symbol layer properties easier, especially since CIMSymbols can contain multiple symbol layers that each have a different color and size. The "get" methods, such as cimSymbolUtils.getCIMSymbolSize() and cimSymbolUtils.getCIMSymbolColor(), help us make sure our inputs are up-to-date whenever a new symbol is selected.

When one of these inputs is changed, you can use one of several "set" methods to update the symbol to the new value. For example, when the color input is adjusted, then the cimSymbolUtils.applyCIMSymbolColor() should be used to adjust the color of the current symbol to the new input value.

Use dark colors for code blocksCopy
1
2
3
4
5
6
// updates all the non color locked symbol layers of the cim symbol
colorInput.addEventListener("calciteInputInput", () => {
  const clonedSym = currentSymbol.clone();
  cimSymbolUtils.applyCIMSymbolColor(clonedSym, colorInput.value);
  handleSymbolUpdate(clonedSym);
});

CIMSymbol.markerPlacement

When a marker symbol (CIMVectorMarker or CIMPictureMarker) is used inside a CIMPolygonSymbol, it needs to define a markerPlacement (either CIMMarkerPlacementInsidePolygon or CIMMarkerPlacementPolygonCenter). All the web styles in this example use CIMMarkerPlacementInsidePolygon, which places the markers inside the polygon at a fixed or random position. Use the toggle under Marker placement properties to toggle between Fixed and Random, and watch how this affects the symbol.

When one of the inputs under Marker placement properties is adjusted, the app updates the markerPlacement properties on the symbol by iterating through each symbol layer, looking for the symbol layer that contains the markerPlacement property, and adjusting the values based on the input values in our app, as shown in the code snippet below.

Use dark colors for code blocksCopy
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
// updates the marker placement on the symbol based on the UI components
function updateMarkerPlacement() {
  let clonedSym = currentSymbol.clone();
  // disable randomness slider if gridType is not Random
  randomnessSlider.disabled = gridType.value !== "Random";
  // disable shift odd rows checkbox if gridType is not Fixed
  shiftOddRows.disabled = gridType.value == "Fixed" ? false : true;
  // find the symbol layer that has marker placement set,
  //    and update based on the current UI values
  clonedSym.data.symbol.symbolLayers.forEach((symLayer, index) => {
    if (symLayer.markerPlacement) {
      let mp = symLayer.markerPlacement;
      mp.gridType = gridType.value;
      mp.randomness = randomnessSlider.value;
      mp.stepX = stepXSlider.value;
      mp.stepY = stepYSlider.value;
      mp.shiftOddRows = shiftOddRows.checked;
      clonedSym.data.symbol.symbolLayers[index].markerPlacement = mp;
    }
  });
  handleSymbolUpdate(clonedSym);
}
Image preview of related sample Intro to CIMSymbol

Intro to CIMSymbol

Learn the basics about CIMSymbol and how to use a primitiveOverride on the text

Image preview of related sample CIMSymbol lines and polygons

CIMSymbol lines and polygons

Learn how to create CIM line and polygon symbols.

Image preview of related sample Arrows along a line

Arrows along a line

Use a CIMSymbol to draw a line with arrow markers at a fixed distance

CIMSymbol

Read the Core API Reference for more information.

Esri Web Style Symbols (2D)

Browse dozens of 2D web styles and copy/paste the required code into your app

Symbol Builder

Symbol Builder application provides a UI for creating any symbol

Your browser is no longer supported. Please upgrade your browser for the best experience. See our browser deprecation post for more details.