Class DefaultStyledDocument
- All Implemented Interfaces:
Serializable, Document, StyledDocument
- Direct Known Subclasses:
HTMLDocument
Warning:
Serialized objects of this class will not be compatible with
future Swing releases. The current serialization support is
appropriate for short term storage or RMI between applications running
the same version of Swing. As of 1.4, support for long term storage
of all JavaBeans
has been added to the java.beans package.
Please see XMLEncoder.
- See Also:
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic classAn UndoableEdit used to remember AttributeSet changes to an Element.classClass to manage changes to the element hierarchy.static classSpecification for building elements.protected classDefault root element for a document... maps out the paragraphs/lines contained.Nested classes/interfaces declared in class AbstractDocument
AbstractDocument.AbstractElement, AbstractDocument.AttributeContext, AbstractDocument.BranchElement, AbstractDocument.Content, AbstractDocument.DefaultDocumentEvent, AbstractDocument.ElementEdit, AbstractDocument.LeafElementModifier and TypeClassDescriptionclassImplements the abstract part of an element.static interfaceAn interface that can be used to allow MutableAttributeSet implementations to use pluggable attribute compression techniques.classImplements a composite element that contains other elements.static interfaceInterface to describe a sequence of character content that can be edited.classStores document changes as the document is being modified.static classAn implementation of ElementChange that can be added to the document event.classImplements an element that directly represents content of some kind. -
Field Summary
FieldsModifier and TypeFieldDescriptionprotected DefaultStyledDocument.ElementBufferThe element buffer.static final intThe default size of the initial content buffer.Fields declared in class AbstractDocument
BAD_LOCATION, BidiElementName, ContentElementName, ElementNameAttribute, listenerList, ParagraphElementName, SectionElementNameModifier and TypeFieldDescriptionprotected static final StringError message to indicate a bad location.static final StringName of elements used to hold a unidirectional runstatic final StringName of elements used to represent contentstatic final StringName of the attribute used to specify element names.protected EventListenerListThe event listener list for the document.static final StringName of elements used to represent paragraphsstatic final StringName of elements used to hold sections (lines/paragraphs).Fields declared in interface Document
StreamDescriptionProperty, TitleProperty -
Constructor Summary
ConstructorsConstructorDescriptionConstructs a default styled document.Constructs a styled document.DefaultStyledDocument(StyleContext styles) Constructs a styled document with the default content storage implementation and a shared set of styles. -
Method Summary
Modifier and TypeMethodDescriptionvoidaddDocumentListener(DocumentListener listener) Adds a document listener for notification of any changes.Adds a new style into the logical style hierarchy.protected voidInitialize the document to reflect the given element structure (i.e. the structure reported by thegetDefaultRootElementmethod.protected AbstractDocument.AbstractElementCreates the root element to be used to represent the default document structure.getBackground(AttributeSet attr) Gets the background color from an attribute set.getCharacterElement(int pos) Gets a character element based on a position.Gets the default root element.getFont(AttributeSet attr) Gets the font from an attribute set.getForeground(AttributeSet attr) Gets the foreground color from an attribute set.getLogicalStyle(int p) Fetches the logical style assigned to the paragraph represented by the given position.getParagraphElement(int pos) Gets the paragraph element at the offsetpos.Fetches a named style previously added.Enumeration<?> Fetches the list of style names.protected voidinsert(int offset, DefaultStyledDocument.ElementSpec[] data) Inserts new elements in bulk.protected voidUpdates document structure as a result of text insertion.voidremoveDocumentListener(DocumentListener listener) Removes a document listener.voidremoveElement(Element elem) Removes an element from this document.voidremoveStyle(String nm) Removes a named style previously added to the document.protected voidUpdates document structure as a result of text removal.voidsetCharacterAttributes(int offset, int length, AttributeSet s, boolean replace) Sets attributes for some part of the document.voidsetLogicalStyle(int pos, Style s) Sets the logical style to use for the paragraph at the given position.voidsetParagraphAttributes(int offset, int length, AttributeSet s, boolean replace) Sets attributes for a paragraph.protected voidstyleChanged(Style style) Called when any of this document's styles have changed.Methods declared in class AbstractDocument
addUndoableEditListener, createBranchElement, createLeafElement, createPosition, dump, fireChangedUpdate, fireInsertUpdate, fireRemoveUpdate, fireUndoableEditUpdate, getAsynchronousLoadPriority, getAttributeContext, getBidiRootElement, getContent, getCurrentWriter, getDocumentFilter, getDocumentListeners, getDocumentProperties, getEndPosition, getLength, getListeners, getProperty, getRootElements, getStartPosition, getText, getText, getUndoableEditListeners, insertString, postRemoveUpdate, putProperty, readLock, readUnlock, remove, removeUndoableEditListener, render, replace, setAsynchronousLoadPriority, setDocumentFilter, setDocumentProperties, writeLock, writeUnlockModifier and TypeMethodDescriptionvoidaddUndoableEditListener(UndoableEditListener listener) Adds an undo listener for notification of any changes.protected ElementcreateBranchElement(Element parent, AttributeSet a) Creates a document branch element, that can contain other elements.protected ElementcreateLeafElement(Element parent, AttributeSet a, int p0, int p1) Creates a document leaf element.createPosition(int offs) Returns a position that will track change as the document is altered.voiddump(PrintStream out) Gives a diagnostic dump.protected voidNotifies all listeners that have registered interest for notification on this event type.protected voidNotifies all listeners that have registered interest for notification on this event type.protected voidNotifies all listeners that have registered interest for notification on this event type.protected voidNotifies all listeners that have registered interest for notification on this event type.intGets the asynchronous loading priority.protected final AbstractDocument.AttributeContextFetches the context for managing attributes.Returns the root element of the bidirectional structure for this document.protected final AbstractDocument.ContentGets the content for the document.protected final ThreadFetches the current writing thread if there is one.Returns theDocumentFilterthat is responsible for filtering of insertion/removal.Returns an array of all the document listeners registered on this document.Supports managing a set of properties.final PositionReturns a position that represents the end of the document.intReturns the length of the data.<T extends EventListener>
T[]getListeners(Class<T> listenerType) Returns an array of all the objects currently registered asFooListeners upon this document.final ObjectgetProperty(Object key) A convenience method for looking up a property value.Element[]Gets all root elements defined.final PositionReturns a position that represents the start of the document.getText(int offset, int length) Gets a sequence of text from the document.voidFetches the text contained within the given portion of the document.Returns an array of all the undoable edit listeners registered on this document.voidinsertString(int offs, String str, AttributeSet a) Inserts some content into the document.protected voidUpdates any document structure as a result of text removal.final voidputProperty(Object key, Object value) A convenience method for storing up a property value.final voidreadLock()Acquires a lock to begin reading some state from the document.final voidDoes a read unlock.voidremove(int offs, int len) Removes some content from the document.voidRemoves an undo listener.voidThis allows the model to be safely rendered in the presence of concurrency, if the model supports being updated asynchronously.voidreplace(int offset, int length, String text, AttributeSet attrs) Deletes the region of text fromoffsettooffset + length, and replaces it withtext.voidsetAsynchronousLoadPriority(int p) Sets the asynchronous loading priority.voidsetDocumentFilter(DocumentFilter filter) Sets theDocumentFilter.voidReplaces the document properties dictionary for this document.protected final voidAcquires a lock to begin mutating the document this lock protects.protected final voidReleases a write lock previously obtained viawriteLock.Methods declared in class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitModifier and TypeMethodDescriptionprotected Objectclone()Creates and returns a copy of this object.booleanIndicates whether some other object is "equal to" this one.protected voidfinalize()Deprecated, for removal: This API element is subject to removal in a future version.Finalization is deprecated and subject to removal in a future release.final Class<?> getClass()Returns the runtime class of thisObject.inthashCode()Returns a hash code value for this object.final voidnotify()Wakes up a single thread that is waiting on this object's monitor.final voidWakes up all threads that are waiting on this object's monitor.toString()Returns a string representation of the object.final voidwait()Causes the current thread to wait until it is awakened, typically by being notified or interrupted.final voidwait(long timeoutMillis) Causes the current thread to wait until it is awakened, typically by being notified or interrupted, or until a certain amount of real time has elapsed.final voidwait(long timeoutMillis, int nanos) Causes the current thread to wait until it is awakened, typically by being notified or interrupted, or until a certain amount of real time has elapsed.
-
Field Details
-
BUFFER_SIZE_DEFAULT
public static final int BUFFER_SIZE_DEFAULTThe default size of the initial content buffer.- See Also:
-
buffer
The element buffer.
-
-
Constructor Details
-
DefaultStyledDocument
Constructs a styled document.- Parameters:
c- the container for the contentstyles- resources and style definitions which may be shared across documents
-
DefaultStyledDocument
Constructs a styled document with the default content storage implementation and a shared set of styles.- Parameters:
styles- the styles
-
DefaultStyledDocument
public DefaultStyledDocument()Constructs a default styled document. This buffers input content by a size of BUFFER_SIZE_DEFAULT and has a style context that is scoped by the lifetime of the document and is not shared with other documents.
-
-
Method Details
-
getDefaultRootElement
Gets the default root element.- Specified by:
getDefaultRootElementin interfaceDocument- Specified by:
getDefaultRootElementin classAbstractDocument- Returns:
- the root
- See Also:
-
create
Initialize the document to reflect the given element structure (i.e. the structure reported by thegetDefaultRootElementmethod. If the document contained any data it will first be removed.- Parameters:
data- the element data
-
insert
protected void insert(int offset, DefaultStyledDocument.ElementSpec[] data) throws BadLocationException Inserts new elements in bulk. This is useful to allow parsing with the document in an unlocked state and prepare an element structure modification. This method takes an array of tokens that describe how to update an element structure so the time within a write lock can be greatly reduced in an asynchronous update situation.This method is thread safe, although most Swing methods are not. Please see Concurrency in Swing for more information.
- Parameters:
offset- the starting offset >= 0data- the element data- Throws:
BadLocationException- for an invalid starting offset
-
removeElement
Removes an element from this document.The element is removed from its parent element, as well as the text in the range identified by the element. If the element isn't associated with the document,
IllegalArgumentExceptionis thrown.As empty branch elements are not allowed in the document, if the element is the sole child, its parent element is removed as well, recursively. This means that when replacing all the children of a particular element, new children should be added before removing old children.
Element removal results in two events being fired, the
DocumentEventfor changes in element structure andUndoableEditEventfor changes in document content.If the element contains end-of-content mark (the last
"\n"character in document), this character is not removed; instead, preceding leaf element is extended to cover the character. If the last leaf already ends with"\n",it is included in content removal.If the element is
null,NullPointerExceptionis thrown. If the element structure would become invalid after the removal, for example if the element is the document root element,IllegalArgumentExceptionis thrown. If the current element structure is invalid,IllegalStateExceptionis thrown.- Parameters:
elem- the element to remove- Throws:
NullPointerException- if the element isnullIllegalArgumentException- if the element could not be removedIllegalStateException- if the element structure is invalid- Since:
- 1.7
-
addStyle
Adds a new style into the logical style hierarchy. Style attributes resolve from bottom up so an attribute specified in a child will override an attribute specified in the parent.- Specified by:
addStylein interfaceStyledDocument- Parameters:
nm- the name of the style (must be unique within the collection of named styles). The name may be null if the style is unnamed, but the caller is responsible for managing the reference returned as an unnamed style can't be fetched by name. An unnamed style may be useful for things like character attribute overrides such as found in a style run.parent- the parent style. This may be null if unspecified attributes need not be resolved in some other style.- Returns:
- the style
-
removeStyle
Removes a named style previously added to the document.- Specified by:
removeStylein interfaceStyledDocument- Parameters:
nm- the name of the style to remove
-
getStyle
Fetches a named style previously added.- Specified by:
getStylein interfaceStyledDocument- Parameters:
nm- the name of the style- Returns:
- the style
-
getStyleNames
-
setLogicalStyle
Sets the logical style to use for the paragraph at the given position. If attributes aren't explicitly set for character and paragraph attributes they will resolve through the logical style assigned to the paragraph, which in turn may resolve through some hierarchy completely independent of the element hierarchy in the document.This method is thread safe, although most Swing methods are not. Please see Concurrency in Swing for more information.
- Specified by:
setLogicalStylein interfaceStyledDocument- Parameters:
pos- the offset from the start of the document >= 0s- the logical style to assign to the paragraph, null if none
-
getLogicalStyle
Fetches the logical style assigned to the paragraph represented by the given position.- Specified by:
getLogicalStylein interfaceStyledDocument- Parameters:
p- the location to translate to a paragraph and determine the logical style assigned >= 0. This is an offset from the start of the document.- Returns:
- the style, null if none
-
setCharacterAttributes
Sets attributes for some part of the document. A write lock is held by this operation while changes are being made, and a DocumentEvent is sent to the listeners after the change has been successfully completed.offsetandlengthdefine the range of the text over which the attributes are set. If the length is <= 0, then no action is taken and the method just returns. If the offset is <=0 or > the length of the text then no action is taken, and the method just returns. Otherwise ifoffset + lengthwill exceed the length of the text then the affected range is truncated.This method is thread safe, although most Swing methods are not. Please see Concurrency in Swing for more information.
- Specified by:
setCharacterAttributesin interfaceStyledDocument- Parameters:
offset- the offset in the document >= 0length- the length > 0s- the attributesreplace- true if the previous attributes should be replaced before setting the new attributes
-
setParagraphAttributes
Sets attributes for a paragraph.This method is thread safe, although most Swing methods are not. Please see Concurrency in Swing for more information.
- Specified by:
setParagraphAttributesin interfaceStyledDocument- Parameters:
offset- the offset into the paragraph >= 0length- the number of characters affected >= 0s- the attributesreplace- whether to replace existing attributes, or merge them
-
getParagraphElement
Gets the paragraph element at the offsetpos. A paragraph consists of at least one child Element, which is usually a leaf.- Specified by:
getParagraphElementin interfaceStyledDocument- Specified by:
getParagraphElementin classAbstractDocument- Parameters:
pos- the starting offset >= 0- Returns:
- the element
-
getCharacterElement
Gets a character element based on a position.- Specified by:
getCharacterElementin interfaceStyledDocument- Parameters:
pos- the position in the document >= 0- Returns:
- the element
-
insertUpdate
Updates document structure as a result of text insertion. This will happen within a write lock. This implementation simply parses the inserted content for line breaks and builds up a set of instructions for the element buffer.- Overrides:
insertUpdatein classAbstractDocument- Parameters:
chng- a description of the document changeattr- the attributes
-
removeUpdate
Updates document structure as a result of text removal.- Overrides:
removeUpdatein classAbstractDocument- Parameters:
chng- a description of the document change
-
createDefaultRoot
Creates the root element to be used to represent the default document structure.- Returns:
- the element base
-
getForeground
Gets the foreground color from an attribute set.- Specified by:
getForegroundin interfaceStyledDocument- Parameters:
attr- the attribute set- Returns:
- the color
-
getBackground
Gets the background color from an attribute set.- Specified by:
getBackgroundin interfaceStyledDocument- Parameters:
attr- the attribute set- Returns:
- the color
-
getFont
Gets the font from an attribute set.- Specified by:
getFontin interfaceStyledDocument- Parameters:
attr- the attribute set- Returns:
- the font
-
styleChanged
Called when any of this document's styles have changed. Subclasses may wish to be intelligent about what gets damaged.- Parameters:
style- The Style that has changed.
-
addDocumentListener
Adds a document listener for notification of any changes.- Specified by:
addDocumentListenerin interfaceDocument- Overrides:
addDocumentListenerin classAbstractDocument- Parameters:
listener- the listener- See Also:
-
removeDocumentListener
Removes a document listener.- Specified by:
removeDocumentListenerin interfaceDocument- Overrides:
removeDocumentListenerin classAbstractDocument- Parameters:
listener- the listener- See Also:
-