/*
* Copyright 2008 Google Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not
* use this file except in compliance with the License. You may obtain a copy of
* the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations under
* the License.
*/
package com.google.gwt.gen2.event.dom.client;
import com.google.gwt.user.client.DOM;
import com.google.gwt.user.client.Event;
/**
* Base class for Key events. The native keyboard events are somewhat a mess
* (http://www.quirksmode.org/js/keys.html), we do some trivial normalization
* here, but do not attempt any complex patching, so user be warned.
*
* @deprecated use the com.google.gwt.event.dom.client classes instead
*/
@Deprecated
public abstract class KeyEvent extends DomEvent {
/**
* Alt modifier.
*/
public static final int MODIFIER_ALT = 4;
/**
* Control modifier.
*/
public static final int MODIFIER_CTRL = 2;
/**
* Meta modifier.
*/
public static final int MODIFIER_META = 8;
/**
* Shift modifier.
*/
public static final int MODIFIER_SHIFT = 1;
/**
* Constructor.
*
* @param nativeEvent the wrapped native event
*/
protected KeyEvent(Event nativeEvent) {
super(nativeEvent);
}
/**
* Gets the key modifiers associated with this event.
*
* @return the modifiers as defined in {@link KeyCodeEvent}.
*/
public int getKeyModifiers() {
Event event = getNativeEvent();
return (DOM.eventGetShiftKey(event) ? MODIFIER_SHIFT : 0)
| (DOM.eventGetMetaKey(event) ? MODIFIER_META : 0)
| (DOM.eventGetCtrlKey(event) ? MODIFIER_CTRL : 0)
| (DOM.eventGetAltKey(event) ? MODIFIER_ALT : 0);
}
/**
* Is the <code>alt</code> key down?
*
* @return whether the alt key is down
*/
public boolean isAltKeyDown() {
return getNativeEvent().getAltKey();
}
/**
* Gets the key-repeat state of this event.
*
* @return <code>true</code> if this key event was an auto-repeat
*/
public boolean isAutoRepeat() {
return getNativeEvent().getRepeat();
}
/**
* Is the <code>control</code> key down?
*
* @return whether the control key is down
*/
public boolean isControlKeyDown() {
return getNativeEvent().getCtrlKey();
}
/**
* Is the <code>shift</code> key down?
*
* @return whether the shift key is down
*/
public boolean isShiftKeyDown() {
return getNativeEvent().getShiftKey();
}
}