/* * @(#)Caret.java 1.30 03/12/19 * * Copyright 2004 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. *
* The dot can be placed by either calling
* setDot
or moveDot
. 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.30 12/19/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);
};