All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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