import PolylineDrawAction from "@arcgis/core/views/draw/PolylineDrawAction.js";const PolylineDrawAction = await $arcgis.import("@arcgis/core/views/draw/PolylineDrawAction.js");- Inheritance
- PolylineDrawAction→
DrawAction→ Accessor
- Since
- ArcGIS Maps SDK for JavaScript 4.5
This class uses different events to generate a set of vertices to create a new Polyline geometry using Draw. When draw.create("polyline") is called, a reference to this class is returned. You can listen to events on the PolylineDrawAction instance, which allows users to create polylines that meet criteria specified by the developer.
- Example
- function enableCreatePolyline(draw, view) {let action = draw.create("polyline");// listen to PolylineDrawAction.vertex-add// Fires when the user clicks, or presses the "F" key// Can also fire when the "R" key is pressed to redo.action.on("vertex-add", function (evt) {createPolylineGraphic(evt.vertices);});// listen to PolylineDrawAction.vertex-remove// Fires when the "Z" key is pressed to undo the// last added vertexaction.on("vertex-remove", function (evt) {createPolylineGraphic(evt.vertices);});// listen to PolylineDrawAction.cursor-update// fires when the pointer moves over the viewaction.on("cursor-update", function (evt) {createPolylineGraphic(evt.vertices);});// listen to PolylineDrawAction.draw-complete// event to create a graphic when user double-clicks// on the view or presses the "Enter" keyaction.on("draw-complete", function (evt) {createPolylineGraphic(evt.vertices);});}function createPolylineGraphic(vertices){view.graphics.removeAll();let polyline = {type: "polyline", // autocasts as Polylinepaths: vertices,spatialReference: view.spatialReference};let graphic = new Graphic({geometry: polyline,symbol: {type: "simple-line", // autocasts as SimpleLineSymbolcolor: [4, 90, 141],width: 3,cap: "round",join: "round"}});view.graphic.add(graphic);}
Constructors
Constructor
Parameters
| Parameter | Type | Description | Required |
|---|---|---|---|
| properties | | |
Properties
| Property | Type | Class |
|---|---|---|
| readonly inherited | ||
| inherited | ||
| | ||
| readonly inherited | number[][] | |
| inherited |
hasZ
- Type
- boolean
Controls whether the created geometry will have z coordinates or not.
- Default value
- true
mode
- Type
- DrawingMode
- Since
- ArcGIS Maps SDK for JavaScript 4.7
The drawing mode. It is only relevant when the action is first created. Its value cannot be changed during the action lifecycle.
Possible Values
| Value | Description |
|---|---|
| hybrid | Vertices are added while the pointer is clicked or dragged. |
| freehand | Vertices are added while the pointer is dragged. |
| click | Vertices are added when the pointer is clicked. |
- Default value
- "hybrid"
- Example
- draw.create("polyline", {mode: "freehand"});
vertices
- Type
- number[][]
Two-dimensional array of numbers representing the coordinates of each vertex comprising the geometry being drawn.
view
- Type
- MapViewOrSceneView
A reference to the MapView.
Methods
| Method | Signature | Class |
|---|---|---|
| inherited | canRedo(): boolean | |
| inherited | canUndo(): boolean | |
| complete(): void | | |
| inherited | emit<Type extends EventNames<this>>(type: Type, event?: this["@eventTypes"][Type]): boolean | |
| inherited | getCoordsAndPointFromScreenPoint(screenPoint: ScreenPoint): FromScreenPointResult | null | undefined | |
| inherited | getCoordsFromScreenPoint(screenPoint: ScreenPoint | null | undefined): number[] | null | undefined | |
| inherited | hasEventListener<Type extends EventNames<this>>(type: Type): boolean | |
| inherited | isFulfilled(): boolean | |
| inherited | isRejected(): boolean | |
| inherited | isResolved(): boolean | |
| inherited | on<Type extends EventNames<this>>(type: Type, listener: EventedCallback<this["@eventTypes"][Type]>): ResourceHandle | |
| inherited | redo(): void | |
| inherited | screenToMap(screenPoint: ScreenPoint): Point | null | undefined | |
| inherited | undo(): void | |
| inherited | when<TResult1 = this, TResult2 = never>(onFulfilled?: OnFulfilledCallback<this, TResult1> | null | undefined, onRejected?: OnRejectedCallback<TResult2> | null | undefined): Promise<TResult1 | TResult2> |
canRedo
- Signature
-
canRedo (): boolean
Indicates if the redo() method can be called on the action instance.
canUndo
- Signature
-
canUndo (): boolean
Indicates if the undo() method can be called on the action instance.
complete
- Signature
-
complete (): void
Completes drawing the polyline geometry and fires the @draw-complete event. Call this method if the drawing logic needs to be completed other than by double-clicking or pressing the "Enter" key.
- Returns
- void
emit
- Signature
-
emit <Type extends EventNames<this>>(type: Type, event?: this["@eventTypes"][Type]): boolean
- Type parameters
- <Type extends EventNames<this>>
Emits an event on the instance. This method should only be used when creating subclasses of this class.
getCoordsAndPointFromScreenPoint
- Signature
-
getCoordsAndPointFromScreenPoint (screenPoint: ScreenPoint): FromScreenPointResult | null | undefined
Maps the given screen point to a map point.
Parameters
| Parameter | Type | Description | Required |
|---|---|---|---|
| screenPoint | The location on the screen. | |
- Returns
- FromScreenPointResult | null | undefined
The result object containing, or
nullif the screen point could not be mapped.
getCoordsFromScreenPoint
- Signature
-
getCoordsFromScreenPoint (screenPoint: ScreenPoint | null | undefined): number[] | null | undefined
Maps the given screen point to a map point.
hasEventListener
- Signature
-
hasEventListener <Type extends EventNames<this>>(type: Type): boolean
- Type parameters
- <Type extends EventNames<this>>
Indicates whether there is an event listener on the instance that matches the provided event name.
Parameters
| Parameter | Type | Description | Required |
|---|---|---|---|
| type | Type | The name of the event. | |
- Returns
- boolean
Returns true if the class supports the input event.
isFulfilled
- Signature
-
isFulfilled (): boolean
isFulfilled() may be used to verify if creating an instance of the class is fulfilled (either resolved or rejected).
If it is fulfilled, true will be returned.
- Returns
- boolean
Indicates whether creating an instance of the class has been fulfilled (either resolved or rejected).
isRejected
- Signature
-
isRejected (): boolean
isRejected() may be used to verify if creating an instance of the class is rejected.
If it is rejected, true will be returned.
- Returns
- boolean
Indicates whether creating an instance of the class has been rejected.
isResolved
- Signature
-
isResolved (): boolean
isResolved() may be used to verify if creating an instance of the class is resolved.
If it is resolved, true will be returned.
- Returns
- boolean
Indicates whether creating an instance of the class has been resolved.
on
- Signature
-
on <Type extends EventNames<this>>(type: Type, listener: EventedCallback<this["@eventTypes"][Type]>): ResourceHandle
- Type parameters
- <Type extends EventNames<this>>
Registers an event handler on the instance. Call this method to hook an event with a listener.
Parameters
| Parameter | Type | Description | Required |
|---|---|---|---|
| type | Type | An event or an array of events to listen for. | |
| listener | EventedCallback<this["@eventTypes"][Type]> | The function to call when the event fires. | |
- Returns
- ResourceHandle
Returns an event handler with a
remove()method that should be called to stop listening for the event(s).Property Type Description remove Function When called, removes the listener from the event.
- Example
- view.on("click", function(event){// event is the event handle returned after the event fires.console.log(event.mapPoint);});
redo
- Signature
-
redo (): void
Incrementally redo actions recorded in the stack. Call canRedo() prior to calling this method
to check if this method can be called on the action instance. Calling this method will fire the vertex-add or
vertex-remove events depending on the last action.
- Returns
- void
- Example
- if (action.canRedo()) {action.redo();}
screenToMap
- Signature
-
screenToMap (screenPoint: ScreenPoint): Point | null | undefined
Maps the given screen point to a map point.
Parameters
| Parameter | Type | Description | Required |
|---|---|---|---|
| screenPoint | The location on the screen. | |
undo
- Signature
-
undo (): void
Incrementally undo actions recorded in the stack. Call canUndo() prior to calling this method
to check if this method can be called on the action instance. Calling this method will fire the vertex-add or
vertex-remove events depending on the last action.
- Returns
- void
- Example
- if (action.canUndo()) {action.undo();}
when
- Signature
-
when <TResult1 = this, TResult2 = never>(onFulfilled?: OnFulfilledCallback<this, TResult1> | null | undefined, onRejected?: OnRejectedCallback<TResult2> | null | undefined): Promise<TResult1 | TResult2>
- Since
- ArcGIS Maps SDK for JavaScript 4.6
when() may be leveraged once an instance of the class is created. This method takes two input parameters: an onFulfilled function and an onRejected function.
The onFulfilled executes when the instance of the class loads. The
onRejected executes if the instance of the class fails to load.
Parameters
| Parameter | Type | Description | Required |
|---|---|---|---|
| onFulfilled | OnFulfilledCallback<this, TResult1> | null | undefined | The function to call when the promise resolves. | |
| onRejected | The function to execute when the promise fails. | |
- Returns
- Promise<TResult1 | TResult2>
Returns a new promise for the result of
onFulfilledthat may be used to chain additional functions.
- Example
- // Although this example uses MapView, any class instance that is a promise may use when() in the same waylet view = new MapView();view.when(function(){// This function will execute once the promise is resolved}, function(error){// This function will execute if the promise is rejected due to an error});
Events
cursor-update
cursor-update: CustomEvent<CursorUpdateEvent> Fires after the pointer moves on the view.
- Example
- // Give a visual feedback to the user as the pointer moves on the view.action.on("cursor-update", function (evt) {view.graphics.removeAll();let polyline = new Polyline({paths: evt.vertices,spatialReference: view.spatialReference});let graphic = createGraphic(polyline);view.graphics.add(graphic);});
draw-complete
draw-complete: CustomEvent<DrawCompleteEvent> Fires after the user has completed drawing a polyline.
- Example
- // listen to PolylineDrawAction.draw-complete// add the graphic representing the completed// polyline to the viewaction.on("draw-complete", function (evt) {removeGraphic(graphic);let polyline = new Polyline({paths: evt.vertices,spatialReference: view.spatialReference});graphic = createGraphic(polyline);view.graphics.add(graphic);});
redo
redo: CustomEvent<VertexAddEvent | VertexRemoveEvent> - Since
- ArcGIS Maps SDK for JavaScript 4.7
Fires in response to redo action or when redo() is called.
- Example
- // Update the graphic on the view as the last action was redoneaction.on("redo", function (evt) {view.graphics.removeAll();let polyline = new Polyline({paths: evt.vertices,spatialReference: view.spatialReference});let graphic = createGraphic(polyline);view.graphics.add(graphic);});
undo
undo: CustomEvent<VertexAddEvent | VertexRemoveEvent> - Since
- ArcGIS Maps SDK for JavaScript 4.7
Fires in response to undo action or when undo() is called.
- Example
- // Update the graphic on the view as the last action was undoneaction.on("undo", function (evt) {view.graphics.removeAll();let polyline = new Polyline({paths: evt.vertices,spatialReference: view.spatialReference});let graphic = createGraphic(polyline);view.graphics.add(graphic);});
vertex-add
vertex-add: CustomEvent<VertexAddEvent> Fires when a vertex is added.
- Example
- // fires when a vertex is added.action.on("vertex-add", function (evt) {view.graphics.removeAll();let polyline = new Polyline({paths: evt.vertices,spatialReference: view.spatialReference});let graphic = createGraphic(polyline);view.graphics.add(graphic);});
vertex-remove
vertex-remove: CustomEvent<VertexRemoveEvent> Fires when a vertex is removed.
- Example
- // Update the graphic on the view as vertex is removedaction.on("vertex-remove", function (evt) {view.graphics.removeAll();let polyline = new Polyline({paths: evt.vertices,spatialReference: view.spatialReference});let graphic = createGraphic(polyline);view.graphics.add(graphic);});