Java tutorial
/******************************************************************************* * Copyright (c) 2000, 2007 IBM Corporation and others. * 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: * IBM Corporation - initial API and implementation * <sgandon@nds.com> - Fix for bug 109389 - DoubleFieldEditor * does not fire property change all the time * 4/1/11 - Barry Hathaway (hathawa@crd.ge.com) - changed to work for doubles *******************************************************************************/ package com.ge.research.sadl.ui.widgets; import org.eclipse.jface.preference.StringFieldEditor; import org.eclipse.jface.resource.JFaceResources; import org.eclipse.swt.widgets.Composite; import org.eclipse.swt.widgets.Text; import com.ge.research.sadl.ui.properties.Messages; /** * A field editor for an double type preference. */ public class DoubleFieldEditor extends StringFieldEditor { private double minValidValue = 0; private double maxValidValue = Double.MAX_VALUE; private static final int DEFAULT_TEXT_LIMIT = 16; /** * Creates a new double field editor */ protected DoubleFieldEditor() { } /** * Creates an double field editor. * * @param name the name of the preference this field editor works on * @param labelText the label text of the field editor * @param parent the parent of the field editor's control */ public DoubleFieldEditor(String name, String labelText, Composite parent) { this(name, labelText, parent, DEFAULT_TEXT_LIMIT); } /** * Creates an double field editor. * * @param name the name of the preference this field editor works on * @param labelText the label text of the field editor * @param parent the parent of the field editor's control * @param textLimit the maximum number of characters in the text. */ public DoubleFieldEditor(String name, String labelText, Composite parent, int textLimit) { init(name, labelText); setTextLimit(textLimit); setEmptyStringAllowed(false); setErrorMessage(Messages.doubleFieldEditorErrorMessage); createControl(parent); } /** * Sets the range of valid values for this field. * * @param min the minimum allowed value (inclusive) * @param max the maximum allowed value (inclusive) */ public void setValidRange(double min, double max) { minValidValue = min; maxValidValue = max; setErrorMessage(Messages.bind(Messages.doubleFieldEditorErrorMessageRange, new Object[] { new Double(min), new Double(max) })); } /* (non-Javadoc) * Method declared on StringFieldEditor. * Checks whether the entered String is a valid doubleeger or not. */ protected boolean checkState() { Text text = getTextControl(); if (text == null) { return false; } String numberString = text.getText(); try { double number = Double.valueOf(numberString).doubleValue(); if (number >= minValidValue && number <= maxValidValue) { clearErrorMessage(); return true; } showErrorMessage(); return false; } catch (NumberFormatException e1) { showErrorMessage(); } return false; } /* (non-Javadoc) * Method declared on FieldEditor. */ protected void doLoad() { Text text = getTextControl(); if (text != null) { double value = getPreferenceStore().getDouble(getPreferenceName()); text.setText("" + value);//$NON-NLS-1$ oldValue = "" + value; //$NON-NLS-1$ } } /* (non-Javadoc) * Method declared on FieldEditor. */ protected void doLoadDefault() { Text text = getTextControl(); if (text != null) { double value = getPreferenceStore().getDefaultDouble(getPreferenceName()); text.setText("" + value);//$NON-NLS-1$ } valueChanged(); } /* (non-Javadoc) * Method declared on FieldEditor. */ protected void doStore() { Text text = getTextControl(); if (text != null) { Double d = new Double(text.getText()); getPreferenceStore().setValue(getPreferenceName(), d.doubleValue()); } } /** * Returns this field editor's current value as an double. * * @return the value * @exception NumberFormatException if the <code>String</code> does not * contain a parsable double */ public double getDoubleValue() throws NumberFormatException { return new Double(getStringValue()).doubleValue(); } }