com.jidesoft.spinner.SpinnerPointModel Maven / Gradle / Ivy
/*
* @(#)SpinnerPointModel.java 4/8/2007
*
* Copyright 2002 - 2007 JIDE Software Inc. All rights reserved.
*/
package com.jidesoft.spinner;
import javax.swing.*;
import java.awt.*;
/**
* @author Nako Ruru
*/
public class SpinnerPointModel extends AbstractSpinnerModel {
public final static int FIELD_X = 0;
public final static int FIELD_Y = 1;
private Point point;
private int field = FIELD_X;
/**
* Create a default SpinnerPointModel
*/
public SpinnerPointModel() {
this(null);
}
/**
* Create a SpinnerPointModel
with a specified Point
*
* @param point this specifiedPoint
*/
public SpinnerPointModel(Point point) {
this.point = point == null ? new Point() : point;
}
/**
* The current element of the sequence. This element is usually displayed by the
* editor
part of a JSpinner
.
*
* @return the current spinner value.
*
* @see #setValue
*/
public Object getValue() {
return point;
}
/**
* Changes current value of the model, typically this value is displayed by the
* editor
part of a JSpinner
. If the SpinnerModel
* implementation doesn't support the specified value then an IllegalArgumentException
* is thrown. For example a SpinnerModel
for numbers might only support values
* that are integer multiples of ten. In that case, model.setValue(new Number(11))
* would throw an exception.
*
* @param value new value
*
* @throws IllegalArgumentException if value
isn't allowed
* @see #getValue
*/
public void setValue(Object value) {
if (value instanceof Point) {
setPoint((Point) value);
}
}
/**
* The current element of the sequence. This element is usually displayed by the
* editor
part of a JSpinner
.
*
* @return the current spinner value.
*
* @see #setPoint(Point)
* @see #getValue()
*/
public Point getPoint() {
return point;
}
/**
* @param point
*/
public void setPoint(Point point) {
if (!this.point.equals(point)) {
this.point = point;
fireStateChanged();
}
}
/**
* @return
*/
public int getField() {
return field;
}
/**
* @param field
*/
public void setField(int field) {
this.field = field;
}
/**
* Return the object in the sequence that comes after the object returned by
* getValue()
. If the end of the sequence has been reached then return null.
* Calling this method does not effect value
.
*
* @return the next legal value or null if one doesn't exist
*
* @see #getValue
* @see #getPreviousValue
*/
public Object getNextValue() {
Point p = (Point) point.clone();
if (field == FIELD_X) {
p.x++;
}
else {
p.y++;
}
return p;
}
/**
* Return the object in the sequence that comes before the object returned by
* getValue()
. If the end of the sequence has been reached then return null.
* Calling this method does not effect value
.
*
* @return the previous legal value or null if one doesn't exist
*
* @see #getValue
* @see #getNextValue
*/
public Object getPreviousValue() {
Point p = (Point) point.clone();
if (field == FIELD_X) {
p.x--;
}
else {
p.y--;
}
return p;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy