/* * Copyright (c) 1997, 2006, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. Oracle designates this * particular file as subject to the "Classpath" exception as provided * by Oracle in the LICENSE file that accompanied this code. * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA * or visit www.oracle.com if you need additional information or have any * questions. */ 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 */ 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. This method is called by UI classes. * * @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. * <p> * If the parameter is negative or beyond the length of the document, * the caret is placed at the beginning or at the end, respectively. * * @param dot the new position to set the caret to */ 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); };