import PointDrawAction from "@arcgis/core/views/draw/PointDrawAction.js";const PointDrawAction = await $arcgis.import("@arcgis/core/views/draw/PointDrawAction.js");- Inheritance:
- PointDrawAction→
DrawAction→ Accessor
- Since
- ArcGIS Maps SDK for JavaScript 4.5
This class uses the view events to generate a set of coordinates to create a new Point geometry using Draw. When the draw.create("point") method is called, a reference to PointDrawAction is returned. Listen to PointDrawAction's @cursor-update and the @draw-complete events to handle the creation of the point geometry.
Example
function enableCreatePoint(draw, view) { let action = draw.create("point");
// PointDrawAction.cursor-update // Give a visual feedback to users as they move the pointer over the view action.on("cursor-update", function (evt) { createPointGraphic(evt.coordinates); });
// PointDrawAction.draw-complete // Create a point when user clicks on the view or presses the "Enter" key. action.on("draw-complete", function (evt) { createPointGraphic(evt.coordinates); });}
function createPointGraphic(coordinates){ view.graphics.removeAll(); let point = { type: "point", // autocasts as /Point x: coordinates[0], y: coordinates[1], spatialReference: view.spatialReference };
let graphic = new Graphic({ geometry: point, symbol: { type: "simple-marker", // autocasts as SimpleMarkerSymbol style: "square", color: "red", size: "16px", outline: { // autocasts as SimpleLineSymbol color: [255, 255, 0], width: 3 } } }); view.graphics.add(graphic);}Constructors
Constructor
Parameters
| Parameter | Type | Description | Required |
|---|---|---|---|
| properties | | |
Properties
| Property | Type | Class |
|---|---|---|
declaredClass readonly inherited | ||
hasZ inherited | ||
vertices readonly inherited | number[][] | |
view inherited |
hasZ
- Type
- boolean
Controls whether the created geometry will have z coordinates or not.
- Default value
- true
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 |
|---|---|---|
canRedo inherited | canRedo(): boolean | |
canUndo inherited | canUndo(): boolean | |
complete(): void | | |
emit inherited | emit<Type extends EventNames<this>>(type: Type, event?: this["@eventTypes"][Type]): boolean | |
getCoordsAndPointFromScreenPoint inherited | getCoordsAndPointFromScreenPoint(screenPoint: ScreenPoint): FromScreenPointResult | null | undefined | |
getCoordsFromScreenPoint inherited | getCoordsFromScreenPoint(screenPoint: ScreenPoint | null | undefined): number[] | null | undefined | |
hasEventListener inherited | hasEventListener<Type extends EventNames<this>>(type: Type): boolean | |
isFulfilled inherited | isFulfilled(): boolean | |
isRejected inherited | isRejected(): boolean | |
isResolved inherited | isResolved(): boolean | |
on inherited | on<Type extends EventNames<this>>(type: Type, listener: EventedCallback<this["@eventTypes"][Type]>): ResourceHandle | |
redo inherited | redo(): void | |
screenToMap inherited | screenToMap(screenPoint: ScreenPoint): Point | null | undefined | |
undo inherited | undo(): void | |
when 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 Point 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. It returns the location of the pointer on the view as an array of numbers representing an x,y coordinate pair in the spatial reference of the view.
Example
action.on("cursor-update", function (evt) { view.graphics.removeAll(); let point = new Point({ x: evt.coordinates[0], y: evt.coordinates[1], spatialReference: view.spatialReference }); let graphic = createGraphic(point); view.graphics.add(graphic);}); draw-complete
draw-complete: CustomEvent<DrawCompleteEvent> Fires after when the user has completed drawing a point. It returns the location of the pointer on the view as an array of numbers representing an x,y coordinate pair in the spatial reference of the view.
Example
action.on("draw-complete", function (evt) { view.graphics.removeAll(); let point = new Point({ x: evt.coordinates[0], y: evt.coordinates[1], spatialReference: view.spatialReference }); let graphic = createGraphic(point); view.graphics.add(graphic);});