API Reference 0.3.24dart_web_toolkit_eventKeyCodeEvent

KeyCodeEvent abstract class

Key up and key down are both events based upon a given key code.

@param <H> handler type

abstract class KeyCodeEvent extends KeyEvent {

 /**
  * Does the key code represent an arrow key?
  *
  * @param keyCode the key code
  * @return if it is an arrow key code
  */
 static bool isArrow(int keyCode) {
   switch (keyCode) {
     case KeyCodes.KEY_DOWN:
     case KeyCodes.KEY_RIGHT:
     case KeyCodes.KEY_UP:
     case KeyCodes.KEY_LEFT:
       return true;
     default:
       return false;
   }
 }

 /**
  * Gets the native key code. These key codes are enumerated in the
  * {@link KeyCodes} class.
  *
  * @return the key code
  */
 int getNativeKeyCode() {
   return getKeyboardEvent().keyCode;
 }

 /**
  * Is this a key down arrow?
  *
  * @return whether this is a down arrow key event
  */
 bool isDownArrow() {
   return getNativeKeyCode() == KeyCodes.KEY_DOWN;
 }

 /**
  * Is this a left arrow?
  *
  * @return whether this is a left arrow key event
  */
 bool isLeftArrow() {
   return getNativeKeyCode() == KeyCodes.KEY_LEFT;
 }

 /**
  * Is this a right arrow?
  *
  * @return whether this is a right arrow key event
  */
 bool isRightArrow() {
   return getNativeKeyCode() == KeyCodes.KEY_RIGHT;
 }

 /**
  * Is this a up arrow?
  *
  * @return whether this is a right arrow key event
  */
 bool isUpArrow() {
   return getNativeKeyCode() == KeyCodes.KEY_UP;
 }

//  String toDebugString() {
//    return super.toDebugString() + "[" + getNativeKeyCode() + "]";
//  }
}

Extends

IEvent<H> > DwtEvent > DomEvent > KeyEvent > KeyCodeEvent

Subclasses

KeyDownEvent, KeyPressEvent, KeyUpEvent

Static Methods

bool isArrow(int keyCode) #

Does the key code represent an arrow key?

@param keyCode the key code @return if it is an arrow key code

static bool isArrow(int keyCode) {
 switch (keyCode) {
   case KeyCodes.KEY_DOWN:
   case KeyCodes.KEY_RIGHT:
   case KeyCodes.KEY_UP:
   case KeyCodes.KEY_LEFT:
     return true;
   default:
     return false;
 }
}

Methods

void assertLive() #

inherited from DwtEvent

Asserts that the event still should be accessed. All events are considered to be "dead" after their original handler manager finishes firing them. An event can be revived by calling {@link GwtEvent#revive()}.

void assertLive() {
 assert (!_dead) ; //: "This event has already finished being processed by its original handler manager, so you can no longer access it";
}

abstract void dispatch(H handler) #

inherited from IEvent

Implemented by subclasses to invoke their handlers in a type safe manner. Intended to be called by EventBus#fireEvent(Event) or EventBus#fireEventFromSource(Event, Object).

@param handler handler @see EventBus#dispatchEvent(Event, Object)

EventType<EventHandler> getAssociatedType() #

inherited from DomEvent

Returns the EventType used to register this event, allowing an EventBus to find handlers of the appropriate class.

@return the type

docs inherited from IEvent<H>
EventType<EventHandler> getAssociatedType() {
 return TYPE;
}

KeyboardEvent getKeyboardEvent() #

inherited from KeyEvent

Cast native event to KeyboardEvent.

dart_html.KeyboardEvent getKeyboardEvent() {
 if (getNativeEvent() is dart_html.KeyboardEvent) {
   return getNativeEvent() as dart_html.KeyboardEvent;
 }
 throw new Exception("Native event is not subtype of KeyboardEvent");
}

Event getNativeEvent() #

inherited from DomEvent

Gets the underlying native event.

@return the native event

docs inherited from HasNativeEvent
dart_html.Event getNativeEvent() {
 assertLive();
 return _nativeEvent;
}

int getNativeKeyCode() #

Gets the native key code. These key codes are enumerated in the {@link KeyCodes} class.

@return the key code

int getNativeKeyCode() {
 return getKeyboardEvent().keyCode;
}

Element getRelativeElement() #

inherited from DomEvent

Gets the element relative to which event coordinates will be measured. If this element is <code>null</code>, event coordinates will be measured relative to the window's client area.

@return the event's relative element

dart_html.Element getRelativeElement() {
 assertLive();
 return _relativeElem;
}

Object getSource() #

inherited from DwtEvent

Returns the source for this event. The type and meaning of the source is arbitrary, and is most useful as a secondary key for handler registration. (See EventBus#addHandlerToSource, which allows a handler to register for events of a particular type, tied to a particular source.)

Note that the source is actually set at dispatch time, e.g. via EventBus#fireEventFromSource(Event, Object).

@return object representing the source of this event

docs inherited from IEvent<H>
Object getSource() {
 assertLive();
 return super.getSource();
}

bool isAltKeyDown() #

inherited from KeyEvent

Is the <code>alt</code> key down?

@return whether the alt key is down

bool isAltKeyDown() {
 return getKeyboardEvent().altKey;
}

bool isAnyModifierKeyDown() #

inherited from KeyEvent

Does this event have any modifier keys down? Specifically. is the control, meta, shift, or alt key currently pressed?

@return whether this event have any modifier key down

bool isAnyModifierKeyDown() {
 return isControlKeyDown() || isShiftKeyDown() || isMetaKeyDown() || isAltKeyDown();
}

bool isControlKeyDown() #

inherited from KeyEvent

Is the <code>control</code> key down?

@return whether the control key is down

bool isControlKeyDown() {
 return getKeyboardEvent().ctrlKey;
}

bool isDownArrow() #

Is this a key down arrow?

@return whether this is a down arrow key event

bool isDownArrow() {
 return getNativeKeyCode() == KeyCodes.KEY_DOWN;
}

bool isLeftArrow() #

Is this a left arrow?

@return whether this is a left arrow key event

bool isLeftArrow() {
 return getNativeKeyCode() == KeyCodes.KEY_LEFT;
}

bool isLive() #

inherited from DwtEvent

Is the event current live?

@return whether the event is live

bool isLive() {
 return !_dead;
}

bool isMetaKeyDown() #

inherited from KeyEvent

Is the <code>meta</code> key down?

@return whether the meta key is down

bool isMetaKeyDown() {
 return getKeyboardEvent().metaKey;
}

bool isRightArrow() #

Is this a right arrow?

@return whether this is a right arrow key event

bool isRightArrow() {
 return getNativeKeyCode() == KeyCodes.KEY_RIGHT;
}

bool isShiftKeyDown() #

inherited from KeyEvent

Is the <code>shift</code> key down?

@return whether the shift key is down

bool isShiftKeyDown() {
 return getKeyboardEvent().shiftKey;
}

bool isUpArrow() #

Is this a up arrow?

@return whether this is a right arrow key event

bool isUpArrow() {
 return getNativeKeyCode() == KeyCodes.KEY_UP;
}

void kill() #

inherited from DwtEvent

Kill the event. After the event has been killed, users cannot really on its values or functions being available.

void kill() {
 _dead = true;
 setSource(null);
}

void overrideSource(Object source) #

inherited from DwtEvent
void overrideSource(Object source) {
 super.setSource(source);
}

void preventDefault() #

inherited from DomEvent

Prevents the wrapped native event's default action.

void preventDefault() {
 assertLive();
 _nativeEvent.preventDefault();
}

void revive() #

inherited from DwtEvent

Revives the event. Used when recycling event instances.

void revive() {
 _dead = false;
 setSource(null);
}

void setSource(source) #

inherited from IEvent

Set the source that triggered this event. Intended to be called by the EventBus during dispatch.

@param source the source of this event. @see EventBus#fireEventFromSource(Event, Object) @see EventBus#setSourceOfEvent(Event, Object)

void setSource(dynamic source) {
 this._source = source;
}

void stopPropagation() #

inherited from DomEvent

Stops the propagation of the underlying native event.

void stopPropagation() {
 assertLive();
 _nativeEvent.stopPropagation();
}

String toString() #

inherited from IEvent

The toString() for abstract event is overridden to avoid accidently including class literals in the the compiled output. Use Event

toDebugString to get more information about the event.

String toString() {
 return "An event type";
}