javauis/eswt_qt/org.eclipse.swt/Eclipse SWT/qt/org/eclipse/ercp/swt/mobile/Input.java
author hgs
Fri, 15 Oct 2010 12:29:39 +0300
changeset 80 d6dafc5d983f
parent 21 2a9601315dfc
permissions -rw-r--r--
v2.2.19_1

/*******************************************************************************
 * Copyright (c) 2004 IBM Corp.
 * Portion Copyright (c) 2008 Nokia Corporation and/or its subsidiary(-ies).
 * All rights reserved. This program and the accompanying materials 
 * are made available under the terms of the Eclipse Public License v1.0
 * which accompanies this distribution, and is available at
 * http://www.eclipse.org/legal/epl-v10.html
 *
 * Contributors:
 *     Mark Rogalski (IBM Corp.) - initial API specification
 *     Nokia Corporation - S60 implementation
 *     Nokia Corporation - QT implementation
 *******************************************************************************/

package org.eclipse.ercp.swt.mobile;

import org.eclipse.swt.SWT;
import org.eclipse.swt.widgets.Display;
import org.eclipse.swt.widgets.Internal_PackageSupport;

/**
 * Instances of this class represent key based input devices.
 * 
 * <dl>
 * <dt><b>Input device types: </b></dt>
 * <dd>SOFTKEYS</dd>
 * <dd>KEYPAD: ITU-T keypad</dd>
 * <dd>LIMITED_KEYBOARD</dd>
 * <dd>FULL_KEYBOARD</dd>
 * </dl>
 * 
 * @see MobileDevice
 * @see MobileDeviceListener
 */
public class Input {

	private boolean		isDisposed;
	
	/**
	 * input device has one or more hardware keys whose meaning can be
	 * configured
	 */
	public static final int SOFTKEYS = 1;

	/**
	 * input device has hardware keys labeled 0 - 9, *, and #
	 */
	public static final int KEYPAD = 2;

	/**
	 * input device has more hardware keys than a keypad, but fewer than a full
	 * keyboard. For instance, number keys may overlap a row of letter keys.
	 */
	public static final int LIMITED_KEYBOARD = 3;

	/**
	 * input device has hardware keys typical in a full keyboard. For instance,
	 * individual keys for all numbers and Latin letters.
	 */
	public static final int FULL_KEYBOARD = 4;
	
    private int location;
    private int type;
    
    /*
     * Constructs a new instance of this class. Non-public to prevent
     * instantiation outside of this package.
     * 
     * @see MobileDevice#getLocalInput
     */
	Input(int aInputId) {
	    
		isDisposed = false;
		getDisplay();
	}
	
	void checkInput () {
	    if(isDisposed) {
	        SWT.error (SWT.ERROR_WIDGET_DISPOSED);
	    }
	}

	/**
	 * Returns the location of the input device.
	 * 
	 * <ul>
	 * <dt>Can be one of:</dt>
	 * <dd>{@link MobileDevice#LOCAL LOCAL}</dd>
	 * <dd>{@link MobileDevice#INTERNAL INTERNAL}</dd>
	 * <dd>{@link MobileDevice#EXTERNAL EXTERNAL}</dd>
	 * <dd>{@link MobileDevice#REMOTE REMOTE}</dd>
	 * </ul>
	 * 
	 * @exception SWTException
	 *                <ul>
	 *                <li>ERROR_WIDGET_DISPOSED - if the receiver has been
	 *                disposed</li>
	 *                </ul>
	 * @exception SWTError
	 *                <ul>
	 *                <li>ERROR_CANNOT_GET_SELECTION - if the operation fails
	 *                because of an operating system failure</li>
	 *                </ul>
	 * 
	 * @see MobileDevice#LOCAL
	 * @see MobileDevice#INTERNAL
	 * @see MobileDevice#EXTERNAL
	 * @see MobileDevice#REMOTE
	 */
	public int getLocation() {
	    checkInput();
	    getDisplay();
	    return location; 
	}

	/**
	 * Returns the type of input device.
	 * 
	 * <ul>
	 * <dt>Can be one of:</dt>
	 * <dd>SOFTKEYS</dd>
	 * <dd>KEYPAD</dd>
	 * <dd>LIMITED_KEYBOARD</dd>
	 * <dd>FULL_KEYBOARD</dd>
	 * </ul>
	 * 
	 * @exception SWTException
	 *                <ul>
	 *                <li>ERROR_WIDGET_DISPOSED - if the receiver has been
	 *                disposed</li>
	 *                </ul>
	 * @exception SWTError
	 *                <ul>
	 *                <li>ERROR_CANNOT_GET_SELECTION - if the operation fails
	 *                because of an operating system failure</li>
	 *                </ul>
	 * 
	 * @see Input#SOFTKEYS
	 * @see Input#KEYPAD
	 * @see Input#LIMITED_KEYBOARD
	 * @see Input#FULL_KEYBOARD
	 */
	public int getType() {
	    checkInput();
	    getDisplay();
	    return type; 
	}
	
	/*
	 * Call to dispose the Input object.
	 */
	void internal_dispose() {		
		isDisposed	= true;		
	}
	
	void setLocation(int aLocation){
		location = aLocation;
	}
	
	void setType(int aType){
		type = aType;
	}
	
	private static Display getDisplay(){
		Display display = Internal_PackageSupport.getDisplayInstance();
		
		// following if loop (getting default display) should be removed
		// if agreed that MobileDevice shouldn't create the display.
		if(display==null){
			display = Display.getDefault();
		}
		if(display == null || display.isDisposed()){
	    	SWT.error(SWT.ERROR_DEVICE_DISPOSED);
	    }
		return display;
	}
}