- /*
- * @(#)Caret.java 1.29 03/01/23
- *
- * Copyright 2003 Sun Microsystems, Inc. All rights reserved.
- * SUN PROPRIETARY/CONFIDENTIAL. Use is subject to license terms.
- */
- package javax.swing.text;
-
- import java.awt.Graphics;
- import java.awt.Point;
- import javax.swing.Action;
- import javax.swing.event.ChangeListener;
-
- /**
- * A place within a document view that represents where
- * things can be inserted into the document model. A caret
- * has a position in the document referred to as a dot.
- * The dot is where the caret is currently located in the
- * model. There is
- * a second position maintained by the caret that represents
- * the other end of a selection called mark. If there is
- * no selection the dot and mark will be equal. If a selection
- * exists, the two values will be different.
- * <p>
- * The dot can be placed by either calling
- * <code>setDot</code> or <code>moveDot</code>. Setting
- * the dot has the effect of removing any selection that may
- * have previously existed. The dot and mark will be equal.
- * Moving the dot has the effect of creating a selection as
- * the mark is left at whatever position it previously had.
- *
- * @author Timothy Prinzing
- * @version 1.29 01/23/03
- */
- public interface Caret {
-
- /**
- * Called when the UI is being installed into the
- * interface of a JTextComponent. This can be used
- * to gain access to the model that is being navigated
- * by the implementation of this interface.
- *
- * @param c the JTextComponent
- */
- public void install(JTextComponent c);
-
- /**
- * Called when the UI is being removed from the
- * interface of a JTextComponent. This is used to
- * unregister any listeners that were attached.
- *
- * @param c the JTextComponent
- */
- public void deinstall(JTextComponent c);
-
- /**
- * Renders the caret.
- *
- * @param g the graphics context
- */
- public void paint(Graphics g);
-
- /**
- * Adds a listener to track whenever the caret position
- * has been changed.
- *
- * @param l the change listener
- */
- public void addChangeListener(ChangeListener l);
-
- /**
- * Removes a listener that was tracking caret position changes.
- *
- * @param l the change listener
- */
- public void removeChangeListener(ChangeListener l);
-
- /**
- * Determines if the caret is currently visible.
- *
- * @return true if the caret is visible else false
- */
- public boolean isVisible();
-
- /**
- * Sets the visibility of the caret.
- *
- * @param v true if the caret should be shown,
- * and false if the caret should be hidden
- */
- public void setVisible(boolean v);
-
- /**
- * Determines if the selection is currently visible.
- *
- * @return true if the caret is visible else false
- */
- public boolean isSelectionVisible();
-
- /**
- * Sets the visibility of the selection
- *
- * @param v true if the caret should be shown,
- * and false if the caret should be hidden
- */
- public void setSelectionVisible(boolean v);
-
- /**
- * Set the current caret visual location. This can be used when
- * moving between lines that have uneven end positions (such as
- * when caret up or down actions occur). If text flows
- * left-to-right or right-to-left the x-coordinate will indicate
- * the desired navigation location for vertical movement. If
- * the text flow is top-to-bottom, the y-coordinate will indicate
- * the desired navigation location for horizontal movement.
- *
- * @param p the Point to use for the saved position. This
- * can be null to indicate there is no visual location.
- */
- public void setMagicCaretPosition(Point p);
-
- /**
- * Gets the current caret visual location.
- *
- * @return the visual position.
- * @see #setMagicCaretPosition
- */
- public Point getMagicCaretPosition();
-
- /**
- * Sets the blink rate of the caret. This determines if
- * and how fast the caret blinks, commonly used as one
- * way to attract attention to the caret.
- *
- * @param rate the delay in milliseconds >= 0. If this is
- * zero the caret will not blink.
- */
- public void setBlinkRate(int rate);
-
- /**
- * Gets the blink rate of the caret. This determines if
- * and how fast the caret blinks, commonly used as one
- * way to attract attention to the caret.
- *
- * @return the delay in milliseconds >= 0. If this is
- * zero the caret will not blink.
- */
- public int getBlinkRate();
-
- /**
- * Fetches the current position of the caret.
- *
- * @return the position >= 0
- */
- public int getDot();
-
- /**
- * Fetches the current position of the mark. If there
- * is a selection, the mark will not be the same as
- * the dot.
- *
- * @return the position >= 0
- */
- public int getMark();
-
- /**
- * Sets the caret position to some position. This
- * causes the mark to become the same as the dot,
- * effectively setting the selection range to zero.
- *
- * @param dot the new position to set the caret to >= 0
- */
- public void setDot(int dot);
-
- /**
- * Moves the caret position (dot) to some other position,
- * leaving behind the mark. This is useful for
- * making selections.
- *
- * @param dot the new position to move the caret to >= 0
- */
- public void moveDot(int dot);
-
- };
-