|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: INNER | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object | +--java.awt.Component | +--java.awt.TextComponent | +--java.awt.TextField | +--edu.hws.jcm.awt.VariableInput
A VariableInput is an input box into which the user can type a real number value, which becomes the value of an associated Variable. The value of the Variable can change only when the VariableInput's checkInput() method is called (usually by a Controller). See the Controller class for more information.
Whenever checkInput is called, an error of type JCMError might be generated. If throwErrors is true, this error is thrown; if it is false, the error is caught, the value of the variable is set to Double.NaN, and no error is thrown. The error message associated with the error can be retrieved by calling getErrorMessage(), if desired. (This value is null if no error occurred the last time checkInput was called.)
A VariableInput is a Value, so it can be used directly where a Value object is needed.
An VariableInput will ordinarily be registered with a Controller in TWO ways: It's added to a Controller with the Controller's add() method. This makes the Controller call the VariableInput's checkInput() method during the Controller's compute() method. Secondly, a Controller is set as the "onUserAction" property. This causes the Controller's compute() method to be called when the user presses return in the VariableInput box. This is optional-- you might, for example, only want the Controller to compute() when a Compute button is pressed. You can also set the VariableInput's onTextChange property to a Controller that you want to compute every time the text in the box changes.
After the VariableInput is created, it is possible to specify the largest and smallest allowed values for the variable. It is also possible to specify what sytle of input is allowed. The style can be to allow any constant expression, constant real numbers only, or integers only. Set these parameters with setMin(), setMax(), and setInputStyle(). For setInputStyle(), the legal parameter values are VariableInput.EXPRESSION, VariableInput.REAL, and VariableInput.INTEGER. The default input style is EXPRESSION.
Inner classes inherited from class java.awt.TextField |
java.awt.TextField.AccessibleAWTTextField |
Inner classes inherited from class java.awt.TextComponent |
java.awt.TextComponent.AccessibleAWTTextComponent |
Inner classes inherited from class java.awt.Component |
java.awt.Component.AccessibleAWTComponent |
Field Summary | |
protected java.lang.String |
errorMessage
Error message from the most recent time checkInput() as called. |
static int |
EXPRESSION
A constant for use in the setInputStyle() method. |
protected boolean |
hasChanged
This is set to true if the text in the box has been changed since the last time the value of the variable was checked by checkInput(). |
protected int |
inputStyle
One of the constant values EXPRESSION, REAL, or INTEGER, specifying the style of input. |
static int |
INTEGER
A constant for use in the setInputStyle() method. |
protected double |
maxValue
Largest allowable value. |
protected double |
minValue
Smallest allowable value. |
static int |
REAL
A constant for use in the setInputStyle() method. |
protected long |
serialNumber
This serial number is increased each time the value of the variable changes. |
protected boolean |
throwErrors
True if an error should be thrown when checkInput() is calles and the contents do not define a legal number. |
protected edu.hws.jcm.awt.VariableInput.VI |
variable
The Variable that represents the value of this input box. |
Fields inherited from class java.awt.TextComponent |
textListener |
Fields inherited from class java.awt.Component |
BOTTOM_ALIGNMENT, CENTER_ALIGNMENT, LEFT_ALIGNMENT, RIGHT_ALIGNMENT, TOP_ALIGNMENT |
Fields inherited from interface java.awt.image.ImageObserver |
ABORT, ALLBITS, ERROR, FRAMEBITS, HEIGHT, PROPERTIES, SOMEBITS, WIDTH |
Constructor Summary | |
VariableInput()
Create an unnamed VariableInput with initial contents "0". |
|
VariableInput(java.lang.String name,
java.lang.String initialString)
Construct a VariableInput with the given name and initial String (which can both be null). |
|
VariableInput(java.lang.String name,
java.lang.String initialString,
Parser parser)
Create a VariableInput just as in the constructor VariableInput(String,String). |
Method Summary | |
void |
addTo(Parser p)
A convenience method that registers this VariableInput's variable with Parser p (but only if both p and the name of the variable are non-null). |
void |
checkInput()
Check whether the contents are valid, and change the value of the associated variable if the new contents do not match the current value. |
protected double |
convertInput(java.lang.String num)
Convert a string into a real value. |
java.lang.String |
getErrorMessage()
Get error message from previous call to checkInput(). |
int |
getInputStyle()
Return the input style, which determines what types of things are allowed in the input box. |
double |
getMax()
Return the maximum value that will be accepted in this VariableInput box. |
double |
getMin()
Return the minimum value that will be accepted in this VariableInput box. |
Controller |
getOnTextChange()
Return the Controller, if any, that is notified when the text in this input box changes |
Controller |
getOnUserAction()
Return the Controller, if any, that is notified when the user presses return in this text-input box. |
long |
getSerialNumber()
Return this object's serial number, which increases whenever the value of the associated variable changes. |
boolean |
getThrowErrors()
Return the value of the throwErrors property. |
double |
getVal()
Return the value of the associated variable, which might not reflect the value of the contents of the input box. |
Variable |
getVariable()
Get the associated variable for the VariableInput box. |
void |
notifyControllerOnChange(Controller c)
Method required by InputObject interface; in this class, it simply calls setOnUserAction(c). |
void |
processActionEvent(java.awt.event.ActionEvent evt)
Overridden to call onUserAction.compute() if onUserAction is non-null. |
void |
processKeyEvent(java.awt.event.KeyEvent evt)
Override processKeyEvent to only allow characters that are legal in this VariableInput. |
void |
processTextEvent(java.awt.event.TextEvent evt)
Overridden to call onUserAction.compute() if onUserAction is non-null. |
void |
setInputStyle(int style)
Specify what types of things are allowed in the input box. |
void |
setMax(double max)
Specify the largest allowed value for the content of this VariableInput box. |
void |
setMin(double min)
Specify the smallest allowed value for the content of this VariableInput box. |
void |
setName(java.lang.String name)
Set the name of the variable. |
void |
setOnTextChange(Controller c)
If the Controller, cm is non-null, then its compute() method will be called whenever the text in this input box changes. |
void |
setOnUserAction(Controller c)
If the Controller, c, is non-null, then its compute() method will be called whenever the user presses the return key while typing in this text-input box. |
void |
setText(java.lang.String text)
This overrides the setText() method from the TextField class so that it will also force the contents to be checked the next time the checkInput() method is called. |
void |
setThrowErrors(boolean throwErrors)
Set the throwErrors property. |
void |
setVal(double d)
Set the value of the associated variable. |
void |
sync(Tie tie,
Tieable newest)
Synchronize serial number and value with newest, unless this VariableInput is itself newest. |
JCMPanel |
withLabel()
Convenience method for creating a component containing this VariableInput together with a label of the form " |
JCMPanel |
withLabel(java.awt.Color back,
java.awt.Color fore)
Convenience method for creating a component containing this VariableInput together with a label of the form "name = ". |
Methods inherited from class java.awt.TextField |
addActionListener, addNotify, echoCharIsSet, getAccessibleContext, getColumns, getEchoChar, getListeners, getMinimumSize, getMinimumSize, getPreferredSize, getPreferredSize, minimumSize, minimumSize, paramString, preferredSize, preferredSize, processEvent, removeActionListener, setColumns, setEchoChar, setEchoCharacter |
Methods inherited from class java.awt.TextComponent |
addTextListener, getBackground, getCaretPosition, getSelectedText, getSelectionEnd, getSelectionStart, getText, isEditable, removeNotify, removeTextListener, select, selectAll, setBackground, setCaretPosition, setEditable, setSelectionEnd, setSelectionStart |
Methods inherited from class java.awt.Component |
action, add, addComponentListener, addFocusListener, addHierarchyBoundsListener, addHierarchyListener, addInputMethodListener, addKeyListener, addMouseListener, addMouseMotionListener, addPropertyChangeListener, addPropertyChangeListener, bounds, checkImage, checkImage, coalesceEvents, contains, contains, createImage, createImage, deliverEvent, disable, disableEvents, dispatchEvent, doLayout, enable, enable, enableEvents, enableInputMethods, firePropertyChange, getAlignmentX, getAlignmentY, getBounds, getBounds, getColorModel, getComponentAt, getComponentAt, getComponentOrientation, getCursor, getDropTarget, getFont, getFontMetrics, getForeground, getGraphics, getGraphicsConfiguration, getHeight, getInputContext, getInputMethodRequests, getLocale, getLocation, getLocation, getLocationOnScreen, getMaximumSize, getName, getParent, getPeer, getSize, getSize, getToolkit, getTreeLock, getWidth, getX, getY, gotFocus, handleEvent, hasFocus, hide, imageUpdate, inside, invalidate, isDisplayable, isDoubleBuffered, isEnabled, isFocusTraversable, isLightweight, isOpaque, isShowing, isValid, isVisible, keyDown, keyUp, layout, list, list, list, list, list, locate, location, lostFocus, mouseDown, mouseDrag, mouseEnter, mouseExit, mouseMove, mouseUp, move, nextFocus, paint, paintAll, postEvent, prepareImage, prepareImage, print, printAll, processComponentEvent, processFocusEvent, processHierarchyBoundsEvent, processHierarchyEvent, processInputMethodEvent, processMouseEvent, processMouseMotionEvent, remove, removeComponentListener, removeFocusListener, removeHierarchyBoundsListener, removeHierarchyListener, removeInputMethodListener, removeKeyListener, removeMouseListener, removeMouseMotionListener, removePropertyChangeListener, removePropertyChangeListener, repaint, repaint, repaint, repaint, requestFocus, reshape, resize, resize, setBounds, setBounds, setComponentOrientation, setCursor, setDropTarget, setEnabled, setFont, setForeground, setLocale, setLocation, setLocation, setSize, setSize, setVisible, show, show, size, toString, transferFocus, update, validate |
Methods inherited from class java.lang.Object |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait |
Field Detail |
protected edu.hws.jcm.awt.VariableInput.VI variable
protected boolean throwErrors
protected java.lang.String errorMessage
protected long serialNumber
protected boolean hasChanged
protected double minValue
protected double maxValue
protected int inputStyle
public static final int EXPRESSION
public static final int REAL
public static final int INTEGER
Constructor Detail |
public VariableInput()
public VariableInput(java.lang.String name, java.lang.String initialString)
public VariableInput(java.lang.String name, java.lang.String initialString, Parser parser)
Method Detail |
public Variable getVariable()
public JCMPanel withLabel()
public JCMPanel withLabel(java.awt.Color back, java.awt.Color fore)
public void setName(java.lang.String name)
setName
in class java.awt.Component
public void addTo(Parser p)
public void setOnUserAction(Controller c)
public Controller getOnUserAction()
public void notifyControllerOnChange(Controller c)
notifyControllerOnChange
in interface InputObject
public void setOnTextChange(Controller c)
public Controller getOnTextChange()
public double getVal()
getVal
in interface Value
public void setVal(double d)
public void setThrowErrors(boolean throwErrors)
public boolean getThrowErrors()
public void setMin(double min)
public double getMin()
public void setMax(double max)
public double getMax()
public void setInputStyle(int style)
public int getInputStyle()
public java.lang.String getErrorMessage()
public void checkInput()
checkInput
in interface InputObject
public long getSerialNumber()
getSerialNumber
in interface Tieable
public void sync(Tie tie, Tieable newest)
sync
in interface Tieable
protected double convertInput(java.lang.String num)
num
- String to be convertedpublic void processKeyEvent(java.awt.event.KeyEvent evt)
processKeyEvent
in class java.awt.Component
evt
- used internally.public void setText(java.lang.String text)
setText
in class java.awt.TextField
text
- change text to this.public void processActionEvent(java.awt.event.ActionEvent evt)
processActionEvent
in class java.awt.TextField
public void processTextEvent(java.awt.event.TextEvent evt)
processTextEvent
in class java.awt.TextComponent
|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: INNER | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |